ANTONIO MARCOS DE AGUIRRA MASSOLA

## AUTOMAÇÃO DE PROJETOS DE SISTEMAS DIGITAIS

## SIMULAÇÃO EM NÍVEL DE PORTAS LÓGICAS

Tese de Doutorado apresentada à Escola Politécnica da Universidade de São Paulo, para obtenção do título de Doutor em Engenharia.

Area de Concentração - Engenha ria de Eletricidade.

Orientador: Prof. Dr. Antonio Hélio Guerra Vieira

São Paulo - 1974 -

FT 441

DEDALUS - Acervo - EPEL



31500013366

ofusi ossi . . .

STREET CONTROL OF THE STREET O

A minha esposa e a meus filhos dedico este trabalho. Allert the sere year that the term of the

#### INDICE

- 1. Introdução
  - 1.1 A importância da simulação em projetos de sistemas digitais
- 2. Aspectos gerais da simulação lógica e o algoritmo desen volvido
  - 2.1 Níveis de simulação lógica
  - 2.2 Características principais associadas a um sistema de simulação
  - 2.3 O algorítmo desenvolvido para o sistema
- 3. O programa para simulação em nível de portas
  - 3.1 Descrição geral
  - 3.2 A estrutura de dados utilizada
  - 3.3 Tabela de símbolos
  - 3.4 Algoritmo para verificação de "fan-in" e "fan-out"
  - 3.5 Estrutura da linguagem de entrada
  - 3.6 Estrutura do simulador propriamente dito
- 4. Manual de utilização do programa de simulação a nível de portas
  - 4.1 Entrada de dados e preparação de cartões
  - 4.2 Codigos de identificação dos cartões
  - 4.3 Formato genérico de um cartão de dados
  - 4.4 Formato de cartões e blocos funcionais permitidos
    - 4.4.1 Blocos funcionais
    - 4.4.2 Cartões de controle para linguagem de entrada
    - 4.4.3 Cartões de controle para o programa simulador
  - 4.5 Controle de erros
    - 4.5.1 Erros detetados pela linguagem de entrada
    - 4.5.2 Erros detetados pelo simulador
- 5. Exemplos de uso do programa de simulação
  - 5.1 Exemplos de utilização da linguagem de entrada e do simulador
- 6. Observações Finais

#### SUMĀRIO

Este trabalho apresenta os principais aspectos da automação de projetos de sistemas digitais com a utilização de computadores, detendo-se particularmente no problema da simulação.

Apresenta uma visão do problema geral da automação e suas diferentes alternativas de solu ção bem como, um relato sobre aspectos da implementação de simuladores.

Introduz um novo algorítmo desen volvido especificamente para atender às necessidades de simulação em nível de registros e portas. Descreve a imple mentação de um simulador em nível de portas lógicas, constituido de rotinas escritas em linguagem Assembler e Fortran do sistema HP 2116B do Laboratório de Sistemas Digitais do Departamento de Engenharia de Eletricidade da Escola Politécnica da Universidade de São Paulo.

Finalmente, apresenta as regras de sua utilização, exemplos e as conclusões mais significa tivas obtidas atraves de seu emprego em vários casos práticos.

#### ABSTRACTS

This paper deals with some basic features of computer-aided automation of digital systems design, particularly with those related to the simulation problem.

It presents a general view of this problem and different approuches for solving it and reports also on the main aspects of simulator implementation.

A new algorithm, developed to meet our specific requirements of register-level and gate level simulation, is described, together with the imple mentation of a gate-level simulator. The latter consists of routines written in the Assembler and Fortran languages of the HP 2116B System and was developed at the Laboratório de Sistemas Digitais do Departamento de Engeharia de Eletricidade da Escola Politécnica da Universida de de São Paulo.

The document also includes rules for the use of the simulator, examples and some relevant conclusions which resulted from the application of the simulator in actual cases.

#### RÉSUMÉ DE L'AUTEUR

Ce travail présente des aspects principaux de l'automatisation des projets de systèmes digitales, avec l'usage des ordinateurs, particulièrement dans le problème de la simulation.

Il prèsente une vision du problème général de l'automatisation e de ses différentes alternatives de solution, aussi comme un rapport sur des aspects de la réa lisation des simulateurs.

Il introduit un nouvel algorithme spécifiquement développé pour pourvoir aux besoins de simu lation au niveau de registres et de portes. Il décrit la réalization d'un simulateur au niveau de portes logiques, construit avec des routines écrites dans les languages Assem bler et Fortran du système HP 2116B du Laboratório de Sistemas Digitais, Departamento de Engenharia de Eletricidade, Escola politécnica da Universidade de São Paulo.

En concluant, il présente les règles pour son usage, des exemples, et les conclusions plus significatives, obtenues à travers son emploi dans plusieurs cas pratiques.

#### AGRADECIMENTOS

Ao Professor Doutor Antonio Hélio Guerra Vieira pelo apoio e constante incentivo.

Aos colegas do Laboratório de Sis temas Digitais e em especial ao grupo de "software", pelo apoio e colaboração nas diversas fases do trabalho.

Aos engenheirandos Claudinê Brandão e Haroldo Masakaju Matsumoto, pelo auxílio no software necessário.

Ao engenheirando Paulo Sérgio Moreira, pela preparação dos exemplos de testes.

As secretárias Marilúcia, Celi manna e Augusta pelos serviços de datilografia.

mente, tenham cooperado para a concretização deste tra balho.

A seada dia con cases a maine a me-CERLS Laventiments do febricantes de eletemas ligitales, po 1. Introdução de production de sintermas per computador la distinción una tra Assir careo, num brotheto de un

# 1.1 <u>A importância da simulação em projetos de sistemas</u> digitais.

A cada dia que passa, é maior a utilização de técnicas de simulação em projetos de sistemas digitais.

Esse fato torna-se cada vez mais e vidente bastando-se para isso, analisar as notícias do cres cente investimento de fabricantes de sistemas digitais, na área de simulação com a utilização de computadores digitais.

Os primeiros passos de ataque ao problema de simulação em técnicas digitais, reportam-se ao ano de 1956 quando S. R. Cray e R. N. Kish apresentaram o trabalho "A Progress Report on Computer Aplications in Computer Design" o qual encontra-se publicado nos "Proceedings do Western Joint Computer Conference (1956)" páginas de 82 a 85.

É então uma área bastante nova e por isso, os seus principais utilizadores encontram estímulo para aumentar investimentos em pesquisas pois, sendo recentíssima é pouca a documentação disponível sobre o assunto com vistas as suas perspectivas de aplicação, apesar dos problemas encontrados, inúmeros trabalhos já podem ser listados na área, todos traduzindo a vital importância da automação de projetos de sistemas por computadores digitais, nos trabalhos que consomem a maior parte do tempo dos projetistas.

Assim sendo, num projeto de um sistema digital onde são inúmeras as fases, em cada uma delas o uso do computador como ferramenta de trabalho é de primor dial importância.

Problemas enfrentados em projeto 16 gico, partição, rotas de circuito impresso, fiação, testes e documentação, são bem orientados em sua solução quando se



Fig. 1.1 -Estrutura geral de um sistema de automação de projetos

dispõe de recursos de automação para vencê-los. Para cada um desses itens encontra-se a aplicação do computador e sua par ticipação deteta ou elimina erros e traz maiores facilidades de documentação de todos os passos seguidos.

Outra área na qual a automação de projetos toma um grande impulso é na implementação de circuitos integrados de larga escala (L.S.I). Trata-se de uma área onde experiências diretas tornam-se muito caras impossibilitando até mesmo pesquisas e só o recurso da simulação permite enfrentar as dificuldades existentes.

um arquivo central com todas as informações iniciais a respeito do projeto a ser desenvolvido a partir daí, atualizá-lo com informações outras, obtidas durante ou após as diferentes etapas do projeto.

Esse arquivo seria então consultado por uma série de programas que executariam cada uma das eta pas citadas e os resultados seriam levados ao arquivo, ou o modificariam.

um sistema desse tipo é o esquematizado na figura 1.1. Apresenta um arquivo central com acesso permitido aos diversos programas de aplicações, os quais podem atualizar as informações disponiveis ou acrescentar no vas informações.

Nêsse sistema, dispõe-se de recursos que permitem concretizar, desde a simulação da lógica proje tada até a parte final do projeto ou seja, os testes que se riam efetuados; em primeiro lugar na máquina simulada e de pois no sistema real, quando este for implementado.

Cada um dos programas é independente e obtém os dados necessários para sua execução a partir de uma linguagem de transcodificação, específica para cada caso. O programa de documentação encarregarse-á de estabelecer a atualização de dados disponíveis e produ zir listagens dos mesmos. No final do projeto poderá fornecer uma documentação total do sistema desenvolvido.

No presente trabalho foi adotado essa estrutura e implementada uma da suas etapas, ou seja, a simula ção lógica em nível de portas, atráves de uma linguagem especial mente desenvolvida.

Embora este trabalho se limite à definição de uma estrutura e à implementação de uma etapa de um to do desejável, outros programas já se encontram em desenvolvimen to ou mesmo prontos e farão parte de um sistema único de automação de projetos, que como foi citado, utilizar-se-á de um arquivo de dados único, do qual serão obtidos os dados necessários a execução de cada programa, e que receberá, eventualmente, após a execução, novas informações.

Aspectos gerais da simulação lógica e o algorítmo desenvolvido.

Totale temperature and the second of the property of the prope

to so welliager some nine de la company

# 2.1 Níveis de simulação lógica

Por simulação lógica entende-se a elaboração de um modêlo do sistema, obedecendo-se a uma determinada estrutura de dados e o seu adequado estímulo a tráves de sinais de testes gerados pelo usuário, obtendo-se assim a resposta do modêlo no decorrer do tempo.

Pode-se atraves de um modêlo do sistema, estudar suas reações e comportamento quando atuan do num sistema real, sem necessidade de sua implementação física e consequentes modificações que se mostram necessá rias para atingir-se o objetivo desejado.

Os níveis de simulação lógica dis poníveis são em número de cinco. A descrição de cada um é apresentado a seguir.

# a. Nivel de arquitetura ou de sis tema

Ao se utilizar êste nível de simu lação, tem-se em mente a análise global das propriedades do sistema em estudo. Os elementos que constituem o sistema são na maioria das vezes, dispositivos bastante complexos e devem ser representados por modelos onde os parâmetros principais dizem respeito aos tempos de resposta ou atra sos, capacidade, etc.

Uma lista de dispositivos presen tes nêsse nível de simulação é constituida dos seguintes e lementos: unidades aritmética e lógica ou simplesmente arit mética, módulos de memória com seus diferentes recursos de implementação: núcleos de ferrite ou semicondutores, portas de seleção, unidades centrais de processamento, decodifica dor, deslocador, contador, etc.

Cada um desses elementos deve ser modelado convenientemente para permitir sua excitação pelo sistema.

A simulação neste nível é feita considerando-se o "timing" do sistema.

#### b. Nivel de Registros

Para se processar a simulação nes te nível, torna-se necessário especificar o fluxo de dados do sistema ao nível de registradores. Neste caso o simulador opera sôbre dados reais e em consequência o sistema pode ser analisado em detalhes e até mesmo programas podem ser executados como se o fossem num sistema real.

Pode-se muitas vezes colocar nês te nível de simulação dispositivos complexos como descrito no ítem a, mas nêste caso devem ter sua descrição e modêlo adequados ao nível de registros.

# c. <u>Nível Lógico</u>

Este nível de simulação é indicado quando se deseja efetuar a simulação utilizando-se as equa ções booleanas que descrevem o sistema. Para isso utilizase apenas os dois níveis lógicos "0" e "1" e o tempo unitário de simulação corresponde ao sinal do relógio central do sistema. Esta simulação é utilizada exclusivamente quando se deseja verificar a lógica do sistema.

# d. Nivel de Portas

Quando se dispõe da descrição do sistema atraves de portas lógicas simples ("gates") inter conectadas, utiliza-se a simulação em nível de portas. Neste caso cada porta deverá ter um modelo bastante real, com parametros indicativos dos atrasos envolvidos, "fan-in" e "fan-out", etc.

#### e. Nivel de Circuitos

As portas descritas para o simula dor em nível de portas podem ser constituidas de interconec ções de resistências, transistores, diodos e condensadores. A sua simulação se desejada nêste nível, será considerada co mo a nível de circuitos e neste caso os dados não se limitarão aos valores lógicos "0" ou "1" mas sim a valores quan titativos que correspondem à indicações de tensão ou corrente.

ção consiste dos circuitos equivalentes dos dispositivos des critos acima.

2.2 - <u>Características principais</u> associadas a um sistema de simulação.

A escolha de uma eficiente estru tura de dados é de grande significado para o sistema que se deseja implementar.

Para se construir a estrutura sobre a qual o simulador operará, duas alternativas são apresentadas ao projetista do programa. A primeira será construí-la a partir de uma linguagem de entrada do tipo compilador, onde, a medida em que se recebe as informações estas serão convertidas em chamadas de sub-programas especificos que executam as funções representadas por um bloco lógico. As chamadas de sub-programas gerados deverão ser interligadas a fim de permitir a descrição lógica da rêde. Após essa montagem, o sistema irá proceder a transformação dessas chamadas em código objeto de máquina para posterior execução.

Nêste caso, o sistema mostrar-se-á pouco eficiente pois se houver atualizações frequentes no projeto estas implicam em atualizar a estrutura atráves de uma nova passagem pela linguagem de entrada e de toda a des crição do sistema, pois um novo código objeto deverá ser obtido.

Uma segunda alternativa será par tir para a obtenção de uma estrutura numérica independente de código objeto de máquina de modo a permitir que, havendo mudanças de projeto estas possam ser fâcilmente absorvidas pelo sistema, sem necessidade de toda a rede sofrer uma no va passagem pela linguagem de entrada mas sim, apenas as modificações.

Neste caso a linguagem de entrada obtém as informações para o sistema e as coloca na estrutu ra como se fôsse preencher uma tabela. O simulador ao ser executado, irá percorrer essa estrutura e a medida que for necessitando dos dados os interpretará para a realização da simulação. Esse fato permite considerar o simulador como interpretador, pois é a interpretação dos dados, sua principal característica.

A estrutura de dados gerada dessa maneira permite ainda a consideração de outros detalhes (co mo por exemplo de que pino procede um sinal) bastando-se para isso apenas sua configuração na estrutura. O sistema ainda é acessível para testes de comportamento, durante a fase de desenvolvimento pois, uma tabela é mais fácil de ser interpretada que um código objeto.

A segunda alternativa foi a adota

Outro ponto a discutir é a escolha do tipo de simulador a ser desenvolvido.

da.

Um simulador, será denominado sin crono quando todos os elementos que constituem sua estrutu ra podem ter seus valores utilizados, apenas a intervalos regulares de tempo, caracterizados pela presença de um sinal de relógio. Assim sendo, os valores assumidos pelo elemento fora desses intervalos padrão, não terão significa dos para o usuário.

Se entretanto, os valores dos sinais que constituem a estrutura puderem ser utilizados tão logo ocorra uma mudança de estado, independendo de intervalos regulares de tempo controlado pelo simulador, ele será denomina do assincrono.

Isso entretanto não implica que cer tos simuladores, ditos sincronos só possam ser utilizados por sistemas sincronos e os assincronos por sistemas assincronos.

Dentre as características associadas a um bloco, uma das principais a ser considerada será o atra so a ele associado. Muitas vezes, como é comum ocorrer, um único atraso não é característica principal de um bloco, pois dependendo do projeto lógico do qual o bloco participa, tornase necessário levar outros atrasos em consideração.

De uma maneira geral o que se considera, é o atraso de propagação que caracteriza o bloco ao variar sua saída do valor lógico "0" para "1", que será deno minado TD01 e o atraso correspondente ao bloco mudar do nível lógico "1" para "0", que será denominado TD10.

Esses atrasos são sempre valores cons tantes e normalmente o que se utiliza, são valôres nominais dos atrasos fornecidos pelo próprio fabricante.

As demais características dos blocos lógicos e que são utilizadas no programa simulador, dizem res peito aos problemas de "fan-in" e "fan-out", bem como, as con dições de testes de sinais de dados, para determinados blocos lógicos, representados pelos tempos de "hold" e de "set-up".

Para se definir o que é "fan-in" ou "fan-out" como utilizado no programa, deve-se antes de mais nada definir-se o que é unidade de carga.

Unidade de Carga é considerada como uma entrada simples de uma porta lógica de uma família qual quer. Isso significa para o caso da família TTL - 7400, uma carga representada pela corrente de menos 1.6 m A quando no estado lógico "0" e de 40 µA quando no estado lógico "1".

"Fan-in" de um bloco lógico é o número obtido pela soma das unidades de carga de todas as entradas do bloco em questão.

"Fan-out" de uma saída, é o número máximo de unidades de carga que podem ser ligadas a essa saída, assegurando os níveis "0" e "1".

O tempo de "hold" é definido como sendo, o intervalo de tempo em que as entradas correspondentes a dados, devem permanecer estáveis, após o pulso de "clock" ter caído abaixo de um determinado valor (ordem 50% ou então 1.5V no caso da família TTL) para as segurar operação correta do "flip-flop".

o tempo de "set-up" é definido co mo sendo, o intervalo de tempo em que as entradas corres pondentes a dados, devem permanecer estáveis, antes da ação do pulso de "clock" no "flip-flop".

A figura ilustra, com a forma de onda, os tempos de "hold" e "set-up".





Fig. 2.1 - Estrutura de dados para o simulador

## 2.3 - O algoritmo desenvolvido para o sistema

A figura 2.2 ilustra o diagrama em blocos do algorítmo.

O algorítmo desenvolvido para utilização na simulação em nível de portas e de registros, consta basicamente de dois elos principais. Cada elo representa uma ação fundamental para cada passo da simulação.

ponde ao primeiro passo da simulação, é chamado de elo da execução; o segundo será chamado elo da ativação. A existên cia desses dois elos éfundamental para o algorítmo e toda simulação será conduzida pela passagem obrigatória atráves desses elos.

Admitir-se-á por ora, que se dispose de uma estrutura de dados numérica, atráves de listas que permitem a ligação de um determinado conjunto de dados da estrutura com o seguinte e assim sucessivamente. O conjunto final da estrutura deverá apresentar mesma organização, apenas apresentando informação adicional que permita indicar que é o último da lista. Detalhes a respeito dessa estrutura de dados serão apresentados na descrição do simulador implementado.

Dentro da estrutura em questão, exis tem para cada conjunto de dados, duas posições bem definidas e necessárias ao algorítmo. A primeira dessas posições será denominada de contador e a segunda de semáforo. Em cada conjunto de dados, tanto o contador como o semáforo permitarão indicar qual o elo que deverá ser processado.

O contador deverá ter conteúdo re presentativo do atraso do bloco que representa na estrutura, e o semáforo será apenas o indicador de atividade para o bloco representado na estrutura. Pode-se verificar a disposição dos elementos citados, na figura 2.1. Apresenta-se ain da, uma outra posição denominada indicador de reativação, cu ja finalidade será descrita quando de sua utilização na descrição do algorítmo.



Fig. 2.2 - Diagrama em blocos do algorítmo desenvolvido

A estrutura de dados é formada por descrição de blocos fornecida pelo projetista, obedecendo aos principios apresentados em 2.1.

O algoritmo inicia-se com uma pré simulação, com a finalidade de se impor condições iniciais para os circuitos lógicos empregados.

A sua finalização é seguida pelo înicio de processamento dos dois elos citados, atráves da lógica descrita a seguir.

Um indicador é posicionado para indicar qual dos elos é para ser processado. Referir-se a figura 2.2.

Inicialmente, este indicador conterá a informação de processamento do elo de execução.

#### ELO DE EXECUÇÃO

Durante esta fase do processamento, a estrutura de dados é percorrida em lotes correspondentes aos conjuntos numéricos representativos de cada bloco a ser simulado, e verifica-se o conteúdo do contador. Se o valor desse contador é positivo, nada deverá ser alterado na estrutura para o bloco em estudo, e com a consulta ao pontei ro indicador do bloco seguinte, este deverá ser analisado.

Se o valor do contador for negativo ou nulo, isso significará uma ordem de execução do bloco
ou seja sua simulação e alteração dos valores numéricos da
estrutura a ele relacionados. Após a execução, o contador
será substituido por um valor positivo qualquer e o próximo
conjunto de dados será analisado após a consulta ao ponteiro conveniente.

Chegando-se ao fim da estrutura de dados, o indicador que estava posicionado para comandar o elo de execução terá seu conteúdo indicando agora o elo de ativação e esse será agora processado.

#### ELO DE ATIVAÇÃO

Durante esta fase, novamente a estrutura será percorrida pelo simulador. Para cada conjunto numérico é agora efetuada a análise do semáforo.

Dessa análise, resultam duas alterna tivas possíveis:

#### o conteúdo do semáforo é zero

Neste caso o algorítmo deve verificar se o bloco em estudo deverá ser ativado. Esta verificação é efetuada atráves do estudo dos estados dos sinais de entra da do bloco e do seu valor atual de saída. Se houver em decor rência, uma necessidade de mudança na saída do bloco, o mesmo deve ser ativado. Isso significa colocar-se no contador o valor do atraso a ser descontado e no semáforo o valor igual a l (ativado). Não havendo causa que justifique a ativação, do semáforo, este permanecerá com seu valor igual a 0.

#### o conteúdo do semáforo não é zero

Neste caso, apesar do bloco estar a tivado por alguma causa anterior (por exemplo, já descontando o contador) deve-se verificar se o mesmo é reativável, o que é possível atráves da consulta à posição R correspondente à informação de reativação. A figura 2.1 indica onde está esta posição. Se for reativável, deve-se verificar se o estado atual das entradas provoca a variação no valor da saída do bloco sen do simulado. Se isso realmente acontece, o bloco deve ter seu contador novamente reposicionado com o valor do atraso cor respondente ao caso em questão. Caso contrário, o processamen to deve prosseguir sem alteração no conteúdo do contador. Se o bloco não é reativável, deve-se prosseguir o processamento, sem alteração no conteúdo do contador permanecendo este com o valor e que deverá ser descontado no momento oportuno.

Em ambos os casos, quer o semáforo contenha ou não zero, o processamento deve prosseguir com a análise do próximo bloco da estrutura.

Durante a fase de teste do semafo ro, deve-se descontar uma unidade de atraso do valor exis tente no contador, para os blocos que estiverem ativados.

O elo de ativação termina quando a consulta à estrutura indicar seu final; neste caso, o al goritmo deve fornecer as informações correspondentes à situação dos blocos simulados e atualizar o tempo de simulação.

A simulação, se necessário prosse guir, continuará com o elo de execução, pois o indicador correspondente a esta atividade foi posicionado após o termino do elo de ativação.

3. O programa para simulação em nível de portas.

ra de manda, establica de continue a describarat, um tracia de . Ha

vivo provides, a maio do ocerndos que ana orienteção e corre

#### 3.1 -Descrição Geral

O sistema implementado consta basica mente de duas partes principais, com funções bem distintas e que quando executadas, fornecem informações básicas para o sistema ou a própria simulação do mesmo.

A figura 3.1 ilustra o esquema geral do programa de simulação em nível de portas lógicas.

As duas partes citadas são:

- a) linguagem de entrada, para leitura de dados e montagem da estrutura;
  - b) simulador propriamente dito.

A linguagem de entrada permite que dados, a serem utilizados para a montagem da estrutura de da dos do simulador, sejam recebidos e armazenados na estrutura de uma maneira conveniente.

Entenda-se como linguagem de entrada, não uma linguagem formal estruturada, mas sim, um programa preparador de dados para a estrutura a ser montada.

Sua função básica é, então, a leitu ra de dados, escolha de controle a executar, montagem da es trutura de dados e indicar se existem ou não erros nas infor mações fornecidas, permitindo, com a impressão do numéro do erro cometido, a ação do operador para sua orientação e correção.

O simulador propriamente dito é cons tituído de várias rotinas que deverão correr toda estrutura montada, modificando-a convenientemente e de acôrdo com os passos seguidos na simulação.



Fig. 3.1 - Esquema Geral do programa de simulação à nível de portas lógicas

Sua função é, então, simular o siste ma, cuja estrutura foi montada pelo programa de leitura de dados, efetuar a leitura de condições iniciais, decidir por tipos de relatórios e pela finalização da simulação.

mo elementos básicos, o algorítmo com dois elos, descrito an teriormente.

# 3.2 - A estrutura de dados utilizada

As informações, a respeito do sistema a ser simulado, a serem fornecidas através da leitura de dados, devem ser montadas em uma estrutura de dados encadeada, onde a ligação de uma parte da estrutura para a seguinte é feita através de ponteiros.

As figuras 3.2 e 3.3 ilustram a es trutura adotada.

A estrutura em questão pode ser ex plicada de uma maneira genérica, como se segue.

Admita-se um bloco de informação. A primeira palavra deste bloco será destinada ao ponteiro indicador do próximo bloco; no caso em estudo, será a primeira posição livre da estrutura de dados, localizada após a com pleta descrição do bloco presente. Isso mostra que essa primeira posição só será preenchida após o processamento de todas as informações do bloco em questão.

A segunda palavra é reservada ao número característico da rotina relacionada com a descrição do bloco. Cada rotina terá um único número, o qual permitirá sua chamada, quer no elo de execução quer no elo de ativação do algorítmo utilizado, quando da exploração da estrutura pelo simulador.

Esse número é utilizado, também, para caracterizar o bloco como sendo uma porta lógica, um bloco lógico, ou um bloco de controle.

A terceira palavra é reservada ao con tador de atrasos, ou seja, a posição que deverá ser consulta da durante o elo de execução para verificar se o bloco deve ser executado ou não.

A quarta palavra é destinada ao semá foro. É esta posição que deverá indicar se o bloco foi ativado ou não e, de sua consulta, dependerá toda lógica existente no elo de ativação.

Esta posição será também chamada de indicadora de ativação.

A quinta palavra é destinada ao indicador de reativação. Esta informação permitirá a verificação da necessidade de se recomeçar a descontar o atraso, quando a variação de sinais de entrada do bloco provoca um sinal de saída diferente daquele que está sendo simulado. Este indicador só é testado quando o bloco já estiver ativado. As pala vras sucessivas da estrutura serão utilizadas para guardar os atrasos típicos do bloco, número e respectivos sinais, função do bloco, áreas de rascunhos, nome do sinal de saída do bloco, etc. A figura 3.2 mostra o significado de cada pala vra de um bloco da estrutura, enquanto a figura 3.3 ilustra o aspecto da estrutura preenchida pelos dados dos dois blocos lógicos, apresentados na própria figura.



Fig. 3.2 - Composição de um bloco típico

Para completar a estrutura de dados, torna-se necessário dispor-se de uma tabela de símbolos na qual serão colocados todos os nomes dos sinais presentes na simulação, sem repetição e contendo como principal característica a informação correspondente ao endereço que ocupam na tabela, o qual será colocado na estrutura de dados e servirá para orientar o simulador, quando necessitar armazenar ou retirar informações já disponíveis pela simulação.

#### 3.3 - Tabela de Símbolos

A figura 3.4 ilustra a organização adotada para a tabela de símbolos.

Esta tabela é necessária para completar a estrutura e servir de auxiliar para a simulação. Consta de seis palavras por registro, sendo que cada registro contém informações de um sinal presente na simulação. As três primeiras palavras de um registro são utilizadas para guar dar o nome do sinal, dois caracteres por palavra, e podendo, portanto, armazenar um nome com até seis caracteres. Para o presente simulador, o nome de sinais deverá ter, no máximo, cinco caracteres, sendo o sexto, obrigatoriamente um branco e colocado na estrutura pela própria linguagem de entrada.

A quarta palavra é utilizada para ar mazenar o endereço do sinal e que é utilizado para ser colocado na estrutura de dados quando a referência ao mesmo fôr efetuada. A figura 3.3 ilustra o fato.

A quinta palavra serve para armaze nar o número que caracteriza o tipo do bloco lógico, ao qual o sinal está ligado.



blocos lógicos identificados por:

| numero 1 | não reativavel | função W | atrasos TD01 | TDIO |
|----------|----------------|----------|--------------|------|
| nnu      | nãc            | fur      | atı          |      |
|          |                |          |              |      |

número 2 reativável função L atrasos TD01 TD10



Fig. 3.3 - Estrutura de dados

#### Tabela de Simbolos



Fig. 3.4 - Estrutura da tabela de Símbolos

A sexta palavra é utilizada para registros de variações de "fan-in" ou "fan-out" do bloco, do qual o sinal procede ou está se dirigindo. O comportamento do circuito quanto ao "fan-in" ou "fan-out" de cada bloco é motivo de um algorítmo específico e que se apresenta a se guir.

A configuração acima descrita, excetuando-se as três primeiras palavras, só é válida durante a primeira fase do processo, quando se está utilizando a linguagem de entrada. Para o simulador propriamente dito, as três primeiras palavras de cada registro não são alteradas mas as três palavras restantes de sua constituição são utilizadas para armazenar dados resultantes da simulação, em nível de bits. Cada palavra do HP 2116B tem 16 bits; pode-se, assim, armazenar 48 unidades de simulação.

Esse dado será importante para uso em determinada rotina do simulador, para a qual é necessário saber o comportamento de um sinal com relação a outro sinal: o de "clock", por exemplo, para se verificar se o mesmo pos sui condições de alterar o valor de saída de um determinado bloco. A rotina para bloco "FLIP-FLOP" utiliza esse recurso, no estudo de problemas de tempo de "holding" ou de "set-up".

Finalmente, as seis primeiras palabras da tabela de símbolos é reservada para o armazenamento de ponteiros indicativos do número de sinais nela existen tes. Essa informação é utilizada no simulador para permitir quer o estabelecimento de condições iniciais para sinais, co mo também para se saber até onde efetuar a pesquisa na tabela para reconhecimento de sinais.

# 3.4 - Algoritmo para verificação de "fan in" e"fan-out"

A necessidade representada pela veri ficação das condições de "fan-in" e "fan-out" de cada bloco, levou a elaboração de um algorítmo que efetua, automaticamen te, a contabilização dos requisitos de correntes de cada si nal que se liga a um dado bloco, bem como para os sinais que, partindo de um dado bloco, se dirige para outro.

O algorítmo elaborado é bem simples e mostrou-se eficiente para solucionar o problema em ques tão.

A figura 3.5 é o diagrama em bloco do algorítmo.

Consta de três partes bem distintas e devem estar presentes no programa que monta a estrutura de dados, ou seja, na linguagem de entrada.

Na primeira parte do algoritmo, efetua-se a colocação de zeros em todas as posições que correspondam à sexta palavra dos registros. Assim, toda a tabela de símbolos tem a sexta palavra com zeros, independentemente do número de sinais que comparecerão na simulação.

A segunda parte do algorítmo é utilizada durante o processamento dos dados que constituem informações para a montagem da estrutura principal, que será utilizada no simulador.

Nesse ponto, o algorítmo deverá decidir para cada sinal presente no bloco se é uma entrada para o mesmo ou saída, e atualizar a posição seis do registro cor respondente ao sinal em questão, somando-se o valor de "fanout" se o sinal representar uma saída, ou subtraindo-se o valor de "fanout" se o sinal representar uma saída, ou subtraindo-se o valor de "fanout" se o sinal for uma entrada.

Existem, entretanto, sinais que procedem de blocos apenas auxiliares na simulação para os quais não há sentido em falar de problemas relacionados com"fan-in"



Fig. 3.5 - Algoritmo de "fan-in" e "fan-out"

ou "fan-out". Para esses sinais, utiliza-se o recurso de não se atualizar sua sexta palavra, como indicado pelo algorítmo mas sim pela colocação de um valor suficientemente grande, que permita sua ação sem perturbar a estrutura do algorítmo.

Após a leitura de todos os dados e sendo detetado o fim da descrição do sistema a simular, outra vez o algorítmo entra em ação com a chamada de sua terceira parte.

Testa-se, agora, se existem valores negativos na sexta palavra dos registros. Cada valor negativo encontrado é representativo de problemas de "fan-in" ou "fan-out" em bloco representado pelo sinal correspondente ao registro em estudo. Neste caso, informa-se ao projetista, dos problemas encontrados e suspende-se a simulação, embora es ses detalhes não impeçam que a mesma se realize. Caso contrário, não havendo problemas, a simulação poderá ser realizada, se desejada.

## 3.5 - Estrutura da linguagem de entrada: COMPI

Procurou-se adotar um sistema no qual o fornecimento de informações se fizesse através de uma ma neira natural, sem imposições de campos definidos, adotando-se, portanto, formato livre para entrada de dados. Esse fato obrigou a elaboração de inúmeras rotinas dedicadas exclusiva mente à leitura e manipulação desses dados. A separação en tre dados é feita através de virgulas.

Na figura 3.6, mostra-se a constitui ção genérica de um cartão de dados, bem como os códigos identificadores de blocos lógicos ou de controles, e na figura 3.7, apresenta-se o diagrama em blocos do programa que constitui a linguagem de entrada.

## formato génerico

CB, nome do bloco, { outras informações a respeito do bloco},

onde CB é o código identificador do bloco ou de controle.

códigos de bloco: A serem colocados como os dois primeiros caracteres de um cartão.

CL - "clock" normal

CR - "clock" reverso

GP - gerador de sinais

GT - bloco porta lógica ("Gate")

FF - bloco "Flip-Flop"

GB - guardar bloco

BL - montar bloco

DB - apagar bloco

códigos de controle: A serem colocados como os dois primeiros ca racteres de um cartão.

\*\* - comentário

DI - guardar no disco

LI - Listar a estrutura montada

LB - Listar blocos gravados

FI - final de estrutura

TE - término de uso da linguagem de entrada

NB - novo bloco



Fig. 3.7 - Linguagem de entrada - Esquema Geral



Fig. 3.7 - continuação

Cada bloco, para ser descrito, deverá ter um código constituído de dois caracteres que o identificará. O programa principal efetua a leitura de toda a in formação que constitui o bloco em questão, sem se preocupar se a mesma está correta e,de acordo com o código que o caracteriza, transfere o controle para a rotina que efetuará agora o tratamento dos dados e verificará se os mesmos estão corretos ou não.

O programa principal da linguagem de entrada, incialmente estabelece valores iniciais para uma sé rie de variáveis necessárias ao controle do programa. Em se guida, efetua a leitura de um cartão de dados (80 caracteres) e os armazena em área de memória, a qual será analisada pelo programa principal apenas nos seus dois primeiros caracteres. Se estes caracteres forem apenas controles, eles posicionarão as variáveis necessárias à sua efetivação, mas se os caracteres forem identificadores de blocos, o programa principal transfere o controle para a rotina específica do bloco, a qual irá agora analisar todas as informações contidas na área de memória preenchida pelo programa principal através da leitura de cartão. Será responsabilidade da rotina a leitura de cartões que contenham informações adicionais para a monta gem da estrutura do bloco em estudo.

Após a execução desta rotina, o controle é devolvido ao programa principal, o qual irá decidir a leitura de novos cartões ou a finalização da descrição da estrutura, dependendo de consulta a ser efetuada às variáveis de controle.

Procedimentos típicos a serem executados pelo programa principal, quando da análise das variá
veis de controle serão, por exemplo: a necessidade de armaze
nar no disco a estrutura existente na memória, segmentar a
estrutura com armazenamento em disco quando houver necessida
de de maiores estruturas de dados, cancelar a simulação quan
do da existência de erros nas informações fornecidas, etc.

sível estruturar blocos bem definidos como por exemplo a representação de uma pastilha de circuito integrado, e após testá-la, armazená-la em arquivos no disco, permitindo sua utilização quando necessário. A maneira de se utilizar os recursos do programa será melhor compreendida através de seu ma nual de uso que se apresenta como um dos elementos desta des crição. Apresenta-se, a seguir, as principais rotinas envolvidas na linguagem de entrada e uma descrição sucinta de como são utilizadas.

#### ROTINAS

- READ Esta rotina é utilizada para lêr as oitenta colunas de um cartão e armazená-las na área de memó ria reservada pelo bloco IREAD.
- N72 Esta rotina verifica, quando chamada, se o cartão lido e cujo conteúdo está na memória, possui continuação. Para isso, efetua o teste da posição do caráter em estudo; se a posição é de ordem menor que 72, nada há a executar mas se a posição é maior ou igual a 72, efetua-se um teste do caráter contido nesta posição. Havendo necessidade de um no vo cartão, este será lido pela própria rotina; ca so contrário, dará uma mensagem de falta de indicador de continuação. O controle da mensagem de er ro é dado pelo indicador da posição dos caracte res. Esse ponteiro é indicado por N.
- PACA Esta rotina é utilizada para efetuar a compactação do nome do sinal. Dessa maneira é possível colocar 6 caracteres máximos, em apenas três palavras.

O nome do sinal é lido e colocado em uma matriz MAT de seis elementos pela rotina GETA; é compactado e colocado nos primeiros três elementos apenas. A matriz MAT está em COMMON.

CONVE - Esta rotina converte um número J de caracteres li
dos, em um valor numérico. Os caracteres estão con
tidos numa matriz NAT de, no máximo, 6 elementos.
A rotina efetua um teste para verificação se os ca
racteres lidos são números. Não sendo, uma mensa
gem de erro será emitida pela rotina.

Esta rotina possui dois argumentos:

"J" - número de caracteres a converter

"NAT" - matriz com os caracteres a converter

- ERRO Esta rotina permite sair com as condições de erro impressas. Para isso, usa variáveis contidas na área de COMMON, uma para indicar qual o número do erro e outra que deverá ser posicionada para indicar que houve erro.
- GETA Esta rotina é utilizada para lêr os caracteres con tidos na área de memória carregada com os dados li dos de cartão. A rotina termina a leitura quando encontrar uma vírgula. Os caracteres lidos da área de memória são colocados na matriz MAT e retorna-se em J com o número de caracteres. A rotina acei ta caracteres brancos e os ignora mas deteta erros quando um nome de sinal tiver mais que cinco caracteres (é o caso do presente programa) ou delimitador "C" no início do nome.

A variável N passa a apontar a primeira posição de caráter logo depois da virgula.

Esta rotina possui dois argumentos:

"J" - número de caracteres lidos da memőria

"NSAI" - indicador de sinal sempre igual a ze

OBS: Este indicador é utilizado pois esta rotina é também requisitada no "simulador de arquitetura", no qual necessita-se ter registrado res, caso em que NSAI poderá ser um. Uma ou tra rotina, neste caso, será necessária. É a GETB que irá analisar o conteúdo de informa ção entre parênteses.

Esta rotina manipula a tabela de símbolos.Permite analisar os sinais contidos na tabela de símbolos e, se fôr necessário adicionar um sinal, ela o fará. Ao pesquisar um sinal na tabela, ela indicará o endereço do registro, se o sinal existir ou então colocará o sinal e indicará seu endereço. É ela que executa a segunda parte do algorítmo de "fan-in" e "fan-out". As informações necessárias à rotina são fornecidas através de argumentos e pela área de COMMON.

A tabela de símbolos é representada pela matriz MSIMB, a qual encontra-se também em COMMON.

Os argumentos desta rotina são os seguintes:

- "NS" número do bloco a considerar
- "IPONT" ponteiro que indica o endereço do sinal pesquisado ou colocado
  - "IE" indica se é um sinal de entrada ("0")
    ou um sinal de saída ("1")
  - "IF" indica ou o valor de "fan-in" ou o va lor de "fan-out"
  - "INF" indica se deve ("1") ou não deve ("0") colocar sinal

Se após o retorno INF é negativo, isto indica que o sinal pesquisado não existe.

O nome do sinal a pesquisar encontra--se na matriz MAT em COMMON.

- KONTR Esta rotina lê o nome dos sinais de entrada de um bloco, a partir das informações existentes na memoria. Utiliza a rotina SIMBA para colocar ou pes quisar sinais na tabela de símbolos.Os argumentos utilizados são os seguintes:
  - "I" número de posições montadas na es trutura de dados
  - "NEAUX" número de sinais de entrada
    - "KA" última posição fixa da estrutura do bloco
    - "IND" indica se a entrada é opcional ou não.
      - "NS" número do bloco a considerar
    - "MODO" indica se entradas ("0") ou saidas ("1")
    - "IFIO" indica o valor do "fan-in"ou do "fan-out"

A rotina também analisa as informações e envia mensagens de erros quando necessárias.

XDISC - É uma rotina para lêr ou gravar informações no dis co. É utilizada tanto para gravar uma estrutura como também na segmentação de estruturas maiores.

Os argumentos necessários para esta rotina são os seguintes:

"IRC" - indica se leitura ("1") ou escrita ("2") no disco

"ISET" - indica o número de setores a lêr ou escrever

"IPRAM"- indica se deve lêr ou gravar a ma triz da estrutura("1") ou a tabe la de símbolos ("2").

A matriz da estrutura é representada pela área de COMMON reservada pela matriz MFUN.

Os arquivos em disco, nos quais são gravadas as duas informações, são respectivamente: # MFUN e # MSIMB.

LISTA - Esta rotina é utilizada para efetuar a listagem da estrutura de dados. Fornece esta lista em octal, decimal e asc. Os argumentos que necessita são ape nas as informações do nome da matriz a listar e do ponteiro que indica até que ponto a listagem deve ser efetuada.

As rotinas que se seguem são chama das pelo programa principal de acordo com o código representado pelos dois primeiros caracteres e analisam as demais in formações contidas na memória. Estas rotinas não possuem ar gumentos, pois os dados necessários estão contidos na área de COMMON. Todas possuem esquemas de identificação de erros e respectivas mensagens, e são programas chamados como seguentos.

CROCO - Esta rotina é utilizada para processar as informações contidas nos cartões que possuem código CL ou CR nas duas primeiras colunas.

Os dados presentes no cartão que descreve este bloco são os seguintes:

"CR" ou "CL" - nome do sinal, período do sinal, largura do pulso,,

A rotina analisa as informações e as coloca na estrutura conforme mostra a figura 3.8.

GATO - Processa as informações contidas nos cartões, cu jo código é GT. Os dados são os seguintes:

"GT" - nome do bloco, função do bloco,

"fan-in", "fan-out", atraso, núme

ro de entradas, entradas

Os dados acima, uma vez analisados, são colocados na estrutura de acordo com o modelo especificado para o bloco. A figura 3.8 ilustra o esquema.

FLIPO - Permite a análise de blocos do tipo "FLIP-FLOP".

Os dados a serem analisados por esta rotina são os que comparecem nos cartões com código FF, e lidos pelo programa principal.

"FF" - (nomes das saidas e "fan-out", (atrasos), (tempos e larguras de sinais), borda, nível, função, (sinais de en trada e "fan-in"),

A estrutura para este tipo de bloco é preenchida como mostra a figura 3.8.

GERAP - Esta rotina analisa as informações contida na me mória e armazenadas a partir da leitura de car tões do tipo:

> "GP" - nível lógico inicial, nome do si nal, periódico ou não, (valores),,

GRAVA - Esta rotina permite gravar blocos em arquivos no disco para posterior utilização. Quando se tem blocos a gravar, torna-se necessário dotá-los de uma estrutura flexível que permita sua fácil utilização. É o caso de representação de pastilhas, motivo pelo qual foi idealizada. Os sinais que se quer ter acesso ao bloco são informados logo após a colocação do nome do bloco. Os cartões que contém essas informações são os que são lidos e que possuem como código os caracteres: GB.

Tratando-se de um conjunto de outros blocos, sua estrutura é bem complexa e se traduz por combina ções de estruturas mostradas na figura 3.8.

Os dados necessários para a rotina são:

"GB" - nome do bloco, (sinais acessíveis),,

Quando utilizada esta rotina, o bloco a ser gravado é colocado em arquivos e o seu nome na biblioteca do sistema que deverá conter também informações adicionais a respeito do bloco em ques tão.

BLOCO - Esta rotina permite lêr informações a respeito de blocos existentes no disco e montá-los na memoria. Utiliza a mesma matriz fundamental da esta trutura de dados e uma matriz especial para conter a tabela de símbolos do bloco lido do arquivo. As informações desta tabela são transferidas sob controle da rotina para a tabela de símbolos normal, à medida que estas são necessárias.

Os dados necessários para a rotina são:

"BL" - nome do bloco, sinais a utilizar ,,

DIREC - Esta rotina é utilizada para listar as informa ções contidas na biblioteca do sistema a respei to dos blocos gravados. Fornece informações quan to ao nome do bloco gravado, dimensões do arqui vo da estrutura de dados e da tabela de símbolos do bloco. É utilizada, também, quando se necessi ta efetuar a listagem da biblioteca, toda vez que se efetuar uma atualização na mesma.

|                                       | Indic-Valor Valor  period. 1 2                                  | RASC 2 entradas                                          | "reset"                                          | asoatrasotempo tempo largura                                            | função: $\begin{vmatrix} 1-JK \\ 2-D \\ 3-MS \end{vmatrix}$ borda ou nível $0 \rightarrow 1 = 1$ |
|---------------------------------------|-----------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| perío dura- nome do cão pulbloco rasc | nivel nome num.de Indic ValorValor lógicobloco res period 1 2 . | atrasoatraso num.  R 0-▶1 1-▶0 sinais função do RASC 1 R | "clock" "set"                                    | nomedanomeda atrasoatrasoatrasoatr<br>saída saída 0 - 1 1 - 0 0 - 1 1 - | c nome nome nome do do do DADO 1 DADO 2                                                          |
| pont, (2)bu(2)                        | pont. (5)                                                       | C S S 1 - NOR                                            | função ( 2 - NAND 3 - NOT 4 - AND 5 - OR 6 - XOR | num.<br>C. S R                                                          | pont. (4) largura largura horda nível RASC la6                                                   |
| CR OUL                                | d'S                                                             | G                                                        |                                                  | Eri<br>Eri                                                              |                                                                                                  |

Fig. 3.8 - Estrutura dos blocos



Fig. 3.9 - Estrutura do Simulador



Fig. 3.9 - conclusão

DELET - Esta rotina é utilizada para a eliminação de blo
cos gravados e para o rearranjo da biblioteca
e dos arquivos. É chamada quando a interpretação
dos dois caracteres iniciais for: DB.

Informações necessárias:

MORDE - Esta rotina efetua a execução da terceira parte do algorítmo de teste de "fan-in" e "fan-out" e coloca os ponteiros indicadores dos sinais existentes na tabela de símbolos. É a última rotina da estrutura de dados antes da chamada do simula dor.

#### 3.6 - Estrutura do simulador: SIMAN

O programa simulador destina-se a cor rer a estrutura de dados montada pela linguagem de entrada e executar os dois elos do algorítmo utilizado.

Consta deum programa principal e várias rotinas que, sob o controle do programa principal, realizam a simulação. Outras rotinas auxiliares completam o si
mulador.

A figura 3.9 é o diagrama em blocos do programa simulador.

A maioria das rotinas opera com as informações contidas na área de COMMON; isto evita a presença de argumentos, facilitando a passagem de dados para as mesmas.

Inicialmente o programa principal se encarrega de colocar valores iniciais em determinadas variáveis que são necessárias ao processo.

Em seguida, efetua-se para todos os sinais presentes na tabela de símbolos, a colocação do valor zero nas palavras de número quatro, cinco e seis de cada registro com a exceção do primeiro, o qual contém os ponteiros para os sinais.

Após esse procedimento, o programa principal, através do chamado da rotina LEITE irá proceder à leitura de valores iniciais para os sinais e será, também, informado dos desejos do usuário quanto aos relatórios e du ração da simulação.

Após a colocação de valores convenientes nas palavras contadora e semáforo de cada bloco, o simulador inicia uma pré-simulação dos blocos portas lógicas a fim de aceitar seus valores iniciais, ou para verificar se os mesmos estão coerentes com a função do bloco. Permiteres alguns ciclos até que se atinja a estabilidade dos mesmos. Após o tempo correspondente aos cilcos permitidos e não tendo-se chegado à estabilização, uma mensagem de alerta é impressa e a simulação termina.

Havendo estabilização, o simulador prosseguirá agora com a primeira fase do algorítmo ou seja o elo de execução. É nesta parte que o número associado a cada bloco terá sua participação, pois dele depende a chama da da rotina, característica do bloco em questão.

Após todos os blocos serem percorridos no elo de execução, o algorítmo inicia sua segunda fase com o início do elo de ativação.

Quando também esta fase terminar, a rotina de relatórios será chamada e deverá providenciar a do cumentação da situação dos sinais na forma escolhida pelo usuário.

Após o relatório, é efetuada a atualização dos sinais e do tempo de simulação, e o algorítmo retorna à sua primeira fase novamente.

As rotinas auxiliares, durante a si mulação, manipulam dados existentes na estrutura principal e na tabela de símbolos. Essas rotinas são as seguintes:

- Esta rotina permite efetuar a atualização dos valores dos sinais, através de um deslocamento de um "bit" em todos os registros nas palavras que contém informações da simulação. Isto é feito para permitir que o "bit" mais significativo contenta o mesmo valor que o seguinte. Para isso o des locamento que se efetua é aritmético. O "bit" mais significativo poderá ser substituído por um novo valor a ser fornecido pela simulação, ou ser mantido, quando não houver alteração durante a mesma.

Esta rotina apenas manipula a tabela de símbolos.

RASAS - Esta rotina é utilizada para colocar o valor simulado de um sinal no "bit" mais significativo da quarta palavra do registro ao qual o sinal per tence. Para isso, o endereço da quarta palavra do sinal é calculado pela rotina ENDER.

A utilização da rotina é efetuada colocando-se no acumulador A, o ponteiro para a posição onde es tã o sinal na estrutura, e no acumulador B o valor do sinal calculado. Em seguida, efetua-se o chamado da rotina RASAS. Como se nota, apenas a tabela de símbolos é manipulada pela rotina.

- Esta rotina é utilizada apenas para efetuar o con fronto entre os dois "bits" mais significativos da quarta palavra de todos os registros. A informação de retorno da rotina é fornecida através do acumulador B. Se para todos os registros a comparação entre os dois "bits" mais significativos, para cada quarta palavra, resultar coincidente, então o acumulador B conterão o valor zero.

Caso contrário, um valor qualquer diferente de ze ro significará que pelo menos um sinal não esta bilizou.

No programa principal, efetua-se o teste da esta bilização dos sinais através do acumulador B.

Nesta rotina, a exemplo das duas anteriores, ape nas a tabela de símbolos é pesquisada.

ENDER - Esta rotina calcula o endereço absoluto da quar ta palavra do registro correspondente a um deter minado sinal. Para tanto, no acumulador A é for necida a posição do sinal na tabela de símbolos. O retorno da rotina é o endereço absoluto da quar ta palavra do sinal, no acumulador B.

A rotina opera, também, como as anteriores, na ta bela de símbolos. CONTR - Esta rotina é utilizada para trazer valores dos sinais de entrada que compareceram na descrição de um determinado bloco. Para isso, deve-se for necer à rotina, através do acumulador B,o número de sinais a considerar e, através do acumulador A, um ponteiro que indica a posição do primeiro sinal. Como retorno, obtém-se, no acumulador A, os valores atuais dos sinais ajustados à direita e no acumulador B os valores anteriores, também ajustados à direita. A rotina fornece, através de um ponteiro em COMMON, a próxima posição da esturura de dados a ser analisada, após os sinais de entrada.

Esta rotina utiliza a estrutura de dados e a tabela de símbolos como elementos de informação.

LEITE - É a rotina que permite efetuar a leitura de da dos para o simulador.

Através dela, condições iniciais são estabelecidas para os sinais, tipos de relatórios são es colhidos, informados os tempos de impressão de sinais e a duração da simulação.

Esta rotina cria uma lista de sinais, cujos valo res deverão ser impressos ou colocados em gráficos de forma de onda.

RELAT - É a rotina que decide o instante em que deve for necer relatórios impressos dos sinais,ou efetuar o traçado da forma de onda dos mesmos.Para saber que sinais deve documentar, utiliza a lista de si nais criada pela rotina LEITE e presente na área

de COMMON. Através desta rotina, pode-se efetuar o cancelamento da simulação através da consulta às chaves de console do computador. Se a chave 1 estiver ligada, o processamento será cancelado.

ERRO - Esta rotina é utilizada para mensagens de erro do simulador.

A rotina de disco aqui presente, é a mesma da lin guagem de entrada, e utilizada para trazer à memória, arquivos existentes no disco, relativos à estrutura de dados e tabela de símbolos. Esses ar quivos contém dados que foram armazenados pela linguagem de entrada, comandado pela presença de um cartão de controle que providencia o armazena mento da estrutura em disco. É utilizado pelo programa auxiliar SIMUL. Este programa só é chama do para colocar os dados da estrutura e tabela de símbolos que foram gravados no disco pelo usuário, na memória.

A rotina que trabalha com a segmentação, está pre sente no proprio programa principal, SIMAN.

As rotinas que se seguem são as que manipulam os blocos lógicos. São constituídas de duas partes que são processadas separadamente pelo elo de execução e pelo elo de ativação.

CROCK - Efetua a simulação de blocos CL ou CR.

Na fase correspondente ao elo de execução, a rotina gera sinal de acordo com a descrição fornecida pelo usuário e coloca o valor simulado na área do sinal na tabela de símbolos. Utiliza-se, para isso, das rotinas auxiliares.

Durante o <u>elo de ativação</u> a rotina nada executa, apenas retorna, o que vale dizer que o semáforo é sempre zero.

GERPA - Esta rotina manipula dados fornecidos por car tões do tipo GP.

Os sinais são gerados de acordo com a descrição fornecida pelo usuário e durante o elo de execução o valor gerado é colocado na área do sinal através do uso de rotinas auxiliares. Inúmeros são os controles executados durante esta fase, como por exemplo, se já foram gerados todos os valores, se o sinal necessita ser repetido etc. Durante o elo de ativação, a rotina apenas retor na, ou seja, o semáforo é sempre zero.

GATES - É a principal rotina do simulador pois énela que o mesmo se apoia. Consta também de duas partes distintas e de um recurso adicional que permite à mesma ser utilizada pelo programa principal du rante a pré-simulação. Nesta fase, a rotina apenas executa a função lógica da porta e coloca o valor simulado na variável que é a saída do bloco.

Pelo fato de ser uma rotina padrão do simulador em termos de utilização dos dois elos do algorít mo, apresenta-se o diagrama em blocos da mesma.

A figura 3.10 é o diagrama em blocos da rotina.

## ELO DE EXECUÇÃO

Coloca, utilizando as rotinas auxiliares, o valor da saída simulada mantida no rascunho da estrutura na posição do sinal na tabela de símbolos. Co



Fig. 3.10 -Estrutura típica de um bloco usando os dois elos

loca zero no semáforo e um valor qualquer positivo no contador.

## ELO DE ATIVAÇÃO

Verifica se a saída do bloco deve mudar com os níveis atuais dos sinais de entrada, compara o valor simulado com o valor anterior do bloco, verifica se o bloco deve ser ativado, encarrega-se de carregar o atraso conveniente no contador do bloco, e posiciona o semáforo quando necessário. A saída do bloco simulada é colocada na área de rascunho existente na estrutura do bloco, quando o mesmo necessitar ativação.

FELIP - Esta rotina trabalha com dados fornecidos pelos cartões de código FF. É bastante complexa mas não se afasta do padrão das demais rotinas.

## ELO DE EXECUÇÃO

Nesta fase consulta-se o rascunho l existente na estrutura de dados e que contém informações a respeito de que sinal de saída do bloco (Q ou Q) de ve ser atualizado na tabela de sinais. Dependen do da consulta, o valor de Q ou Q ou ambos contidos em outros rascunhos são colocados através de rotinas auxiliares na tabela de símbolos. Os que não forem transferidos, continuam nos rascunhos e um atraso diferencial é colocado no contador, man tendo-se o bloco ativado.

Se todos os valores forem atualizados, coloca-se zero no semáforo e um valor diferente de zero, mas positivo, no contador.

## ELO DE ATIVAÇÃO

Durante esta fase, efetua-se testes nos sinais fornecidos pelo usuário para verificar se o blo co deve ser ativado ou não. Havendo necessidade de ativação, os valores de saída do bloco(Q, Q), são simulados e colocados nos rascunhos, coloca-se no contador o valor do atraso conveniente e indica-se no rascunho 1 de informação, que sinal de saída deve ser atualizado em primeiro lugar. O semáforo é posicionado com o valor 1, indicativo de bloco ativado.

Durante esta fase, são efetuados testes com os sinais de dados e de duração dos sinais de contro le. Esses testes são efetuados apenas quando o usuário o desejar. 4. Manual de utilização do programa de simulação em nível de portas.

# 4.1 - Entrada de dados e preparação dos cartões

A entrada de informações para o programa é efetuada através de cartões perfurados. Pode-se a qualquer momento, se assim o usuário o desejar, efetivar a entrada de dados através de fita magnética ou fita de papel, bastando que se efetue a substituição do dispositivo de entrada para o programa. (O sistema HP é bastante flexível nesse aspecto.)

.Os cartões devem descrever a interligação do sistema pela descrição de cada um dos seus blocos funcionais.

Dependendo do bloco funcional, que se deseja descrever, varia o formato do cartão de dados. A única informação fixa que esses cartões possuem, dizem res peito às suas primeiras colunas nas quais existe o código do bloco a ser utilizado.

Para a codificação de dados podem ser utilizadas as colunas de 1 a 71 do cartão. Se a informação deve continuar em outro cartão, um (\*) deve ser perfurado na coluna 72 do cartão.

Dentro de um cartão a codificação é de formato livre, sendo os campos separados um dos outros por meio de ",". O fim da informação é caracterizado por "," e pela análise de outras informações já obtidas do cartão.

.Quando falta uma informação (que se ja opcional) deve-se colocar no cartão apenas as duas virgu-las seguidas ",," indicando o fato.

. Caracteres brancos são ignorados.

.Os nomes de sinais devem conter no máximo cinco caracteres quaisquer, a menos de "(".

## 4.2 - Códigos de identificação do cartão

. Nas duas primeiras colunas do cartão deve comparecer um dos seguintes códigos:

BL - Montar bloco na memória

CL - gerador de "clock" normal

CR - gerador de "clock" reverso

DB - apagar bloco existente na biblioteca do sistema

DI - gravar em disco

FF - bloco "FLIP-FLOP"

FI - fim de descrição da estrutura

GB - guardar bloco na biblioteca do sistema

GP - gerador de sinais

GT - bloco porta lógica

LB - listar blocos existentes na biblioteca do sistema

LI - listar a estrutura de dados montada

NB - novo bloco a gravar

TE - término de uso da linguagem de entrada

\*\* - comentário

## 4.3 - Formato genérico de um cartão de dados

. Cada bloco possui um formato diferente e variavel de cartão de entrada que contem as informações acerca de sua estrutura. Assim sendo, para se obter o formato exato e a maneira correta de preenchimento dos cartões de entrada, deve-se consultar sempre a descrição do cartão de carda bloco funcional, em confronto com os exemplos apresentados.

. O formato genérico do cartão é o seguinte:

onde,

CB

- é o código que identifica o blocofuncional
- nome do bloco é o nome identificador do próprio bloco e deve rá conter o estado atual e os valores anteriorres da simulação do bloco. Representa, na verdade, o nome do sinal que sai do bloco.
- correspodem aos atrasos que o bloco possui e que são necessários durante a simulação. Geral mente são em número de dois: o atraso que cor responde ao tempo necessário para a saída passar do estado "0" para o estado "1" (TD01) e o atraso que corresponde ao tempo necessário para a saída passar do estado "1" para o estado "0" (TD10). Sua unidade de tempo é em nanosegun dos e o valor unitário de um atraso é o tempo unitário ou passo da simulação.
- "fan-in" é um número que indica o valor de carga normalizada para cada entrada do bloco
- "fan-out" é um número que indica o valor de carga normalizada para a saída do bloco
- <u>função</u> indica qual a função a ser executada pelo bloco funcional, quando assim se fizer necessário, (por exemplo: função AND, OR, NOR etc.).
- entradas é a lista dos nomes dos sinais de entradas para o bloco. Quando necessário deverá ser acompanha da das informações de "fan-in" ou de "fan-out".

# 4.4 - Formato de cartões e blocos funcionais permitidos

## 4.4.1 - Blocos funcionais

## . porta lógica ("gates"): GT

O cartão de entrada deve ser codificado da seguinte forma: GT, nome do bloco, função, "fan-in", "fan-out", TD01, TD10, número de entradas, entradas,

onde:

funções permitidas para a porta lógica são: AND, NOR, NAND, NOT, OR, XOR

nº de entradas- é o número de sinais que alimentam o bloco, ou seja, o número de entradas ocupadas.

#### Exemplos:

GT, RB1, AND, 1, 1, 5, 5, 2, D1, STROB ,, GT, FLOS, NOT, 1, 10, 1, 2, 1, FLIS ,, GT, QB, NOR, 1, 16, 3, 1, 2, FLIS, FLOS ,,

#### . bloco "FLIP-FLOP": (FF)

As informações que devem ser fornecidas através deste cartão são as seguintes:

FF, saida Q, "fan-out", saida Q, "fan-out", TD01, TD10, TD01,

\*1 \*1 \*1

TD10, TD01, TD10, t"set-up", t"hold", Larg"clock", Larg"set",

\*2 \*3 \*3

Larg"reset", borda, nivel, função, nome do "clock", "fan-in",

nome do "set", "fan-in", nome do "reset", "fan-in", Dado 1,

"fan-in", Dado 2, "fan-in",

#### onde:

dizem respeito ao sinal de "clock" \*1 dizem respeito ao sinal de "set" \*2 dizem respeito ao sinal de "reset" \*3 é o tempo de "set-up" para o dado t"set-up" é o tempo de "hold" para o dado t"hold" larg"set", larg"reset" - correspondem às largu Larg"clock", ras necessárias aos sinais de "clock", "set", "reset" especifica que o bloco é sensível à borda do borda "clock", ou seja, ou de 0-1 (01) ou de 1-0 (10)indica que os sinais atuam quando em nível lo nivel

gico "0" (10) ou nível lógico "1" (01)

função o bloco "FLIP-FLOP" pode executar as funções de bloco JK, D ou Ms.

dado l no caso do bloco ter função de JK, é.o J; no caso de função D, é o próprio dado.

dado 2 no caso do bloco ter função JK, é o K; no caso de função D, deve-se colocar ",,".

## Observações:

- As informações desde t"set-up" até larg"reset" são opcionais e não existindo dados deve-se colocar a condição de opcional.
- 2. Os sinais de "clock", "set" e "reset" também são opcionais. No caso de um deles não aparecer, o correspondente "fan-in" não deverá constar no cartão.
- 3. As larguras e tempos de "set-up" e "hold" não devem ser maiores que 32 unidades de tempo.

#### Exemplos:

#### "master-slave" completo:

FF, Q, 1, QB, 1, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 01, 01, MS, CL 1, SET, 1, RESET, 1, J, 1, K, 1,

"JK" com "clock" e dados e sem testes de tempos e larguras:
FF, Q, 1,QB, 2, 1, 1, 1, 1, 2, 2,,,,,01, 01, JK, CL, 1,,,J,
1, K, 1,,

# .Gravação de blocos lógicos definidos pelo usuário: (GB)

O uso de blocos, como o "FLIP-FLOP" definido acima, é bastante deficiente sob o ponto de vista de utilização. O presente programa permite ao usuário a definição de blocos "FLIP-FLOP" em nível de portas lógicas, seu tes te, gravação e posterior utilização como se fôsse uma pastilha de circuito integrado. Para tanto, uma vez efetuada a

definição do bloco a se utilizar, em nível de portas lógicas, basta que o usuário efetue a escolha dos sinais que deseja ter acesso e os coloque como informações no cartão que efetua a gravação.

Cada bloco terá um nome que deverá constar da descrição do cartão. Este nome será pesquisado na biblioteca do sistema e, não havendo duplicação, será arquivado.

O cartão que permite gravar blocos tem o seguinte formato:

GB, nome do bloco, (nome dos sinais acessíveis),,

A sequência dos sinais é importante e devem ser os mesmos existentes na descrição da estrutura do bloco que se deseja gravar.

## Exemplos:

1. Após os cartões em nível de porta lógica e que des crevem um "DUAL JK - NEGATIVE EDGE TRIGGERED FLIP-FLOP" que constitui a pastilha de nome 74S113, deve-se colocar o cartão de gravação:

GB, S113, PRESE, CLEAR, CLOCK, J, K, Q, QB,

onde: PRESE, CLEAR, CLOCK, J, K, Q, QB, são os sinais acessíveis.

2. Após a descrição de um "DUAL D TYPE EDGE TRIGGERED FLIP-FLOP", que constitue a pastilha 74S74, deve-se colocar o cartão:

GB, S7474, PRESS, CLEAR, CLOCK, DADO, Q, QB,,

onde: PRESS, CLEAR, CLOCK, DADO, Q e QB são os sinais acessíveis.

## . Montagem de blocos definidos pelo usuário: BL

Após a gravação de blocos especifica dos pelo usuário, como mostrado no item anterior, o mesmo po derá ser utilizado quando desejado, bastando apenas que seja

chamado através de um cartão do tipo <u>BL</u>. O nome do bloco deverá ser um dos presentes na biblioteca do sistema e os sinais que se quer utilizar, terão o mesmo significado que na gravação, mas o nome poderá ser aquele que o usuário necessitar na montagem do seu sistema.

O usuário poderá utilizar o mesmo bloco, o número de vezes que julgar necessário.

O cartão que permite a montagem dos blocos tem as seguintes informações:

BL, nome do bloco, (sinais a utilizar),,

#### Exemplos:

A chamada para montagem da pastilha S7474, do item anterior, será:
BL, S7474, PRESE, LIMPA, RELOL, DADO, FLIP, FLOP,

.Eliminação de blocos da biblioteca: DB

Os cartões que possuem nas duas primeiras colunas o código DB, permitem a eliminação de blocos
arquivados e cujos nomes encontram-se presentes na biblioteca do sistema. Após a eliminação efetua-se uma compactação
dos arquivos e atualização da biblioteca.

O formato do cartão é o seguinte:

DB, (nomes dos blocos),,

Exemplos:

DB, S113, S7474 ,,

## .Gerador de "clock" normal e reverso: CL, CR

Os cartões do tipo CL e CR permitem gerar sinais de "clock" com período e largura definidos. O "clock" normal é um sinal que inicia-se no nível lógico "0"e vai para o nível "1", como mostra a figura:



O "clock reverso é idêntico; apenas que no início o sinal sai do nível "1" e vem para "0".

A figura ilustra o "clock" reverso:



Os cartões que descrevem os geradores

de "clock" tem as seguintes informações:

```
| CL | nome do sinal, período, duração do pulso ,,
```

#### Exemplos:

CL, CLOCK, 100, 30 ,, CR, CROCO, 100, 30 ,,

#### .Gerador de sinais: GP

O gerador de sinais permite a formação de um sinal desejado para testes pois sua composição é
deixada ao critério do próprio usuário. Como no caso do gera
dor de "clock", aqui tembém torna-se necessário especificar
qual o nível lógico de partida.

Na especificação de um sinal, a dura ção do intervalo no qual o sinal deve permanecer num determinado nível lógico é denominado de valor.

As informações necessárias são as se

guintes:

onde:

- \*1 indica o nível lógico de início. Se "0", o sinal começa no nível "1" e vem para "0".
- \*2 o sinal gerado pode ser repetido um certo número de vezes. Deve ser especificado este número. Se o sinal deve
  ser gerado uma única vez, coloca-se o indicador de opcional. Neste caso, após a geração do último valor, o
  nível do sinal será o oposto ao último gerado.

Observação: o número máximo de valores é 10.

Exemplos:

A geração de um sinal com a forma de onda especifi

cada pela figura:



será obtida com o cartão:
GP, 0, SAIDA, 10, 10, 20, 10,

## 4.4.2 - Cartões de controle para a linguagem de entrada

O programa que efetua a leitura dos cartões de entrada, que descrevem a estrutura de dados a ser montada para o simulador, é gerenciado através dos seguintes tipos de cartões:

| COLUNA 1 |                 |
|----------|-----------------|
| NB ,,    | (Novo Bloco)    |
| LB ,,    | (Listar Blocos) |
| DI ,,    | (Discos)        |
| FI ,,    | (final)         |
| LI ,,    | (Lista)         |
| TE ,,    | (Termina)       |
| **       | (Comentário)    |

A utilização de cada cartão é assim

#### descrita:

- a Sequência de entrada para a linguagem de entrada.
  - a.1 Os cartões DI ,, e LI ,, devem, se desejada a sua utilização, vir logo a seguir do cartão de chamada do programa que constitue a linguagem de entrada.

#### :PR, COMPI

- a.2 Seguem-se os cartões de descrição do sistema a ser simulado. Pode-se colocar cartões de comentário que devem obrigatóriamente ter um \* nas colunas 1 e 2.
- a.3 Encerra-se a descrição do sistema com cartão FI ,...

  No caso de gravação de blocos, não é permitida a presença do cartão FI ,. e sua função é substituida pelo cartão de gravação (GB) o qual encerra a descrição do bloco e o armazena no disco. Entre um bloco e outro deve comparecer o cartão NB ,...
- a.4 Vem a seguir os cartões ou de término da linguagem de entrada (TE ,,) ou de chamada do simulador (SI,).
- a.5 O cartão LB ,, permite listar a biblioteca de blocos gravados.

## b) - Função de cada cartão

LI,, permite, quando presente, listar a matriz fundamental estruturada para o sistema em questão. Sua utilidade é na depuração de programas.

- DI,, indica quando presente, que a estrutura montada a partir dos cartões deve, se não houver erros, ser arquiva da no disco para uso imediato e futuro.
- FI,, sua presença é obrigatória. Indica para a linguagem de entrada a finalização de descrição dos dados do sistema.
- TE,, quando presente encerra o processamento. (Só é utilisa do para a linguagem de entrada).
- SI,, é utilizado para, através da linguagem de entrada, efe tuar a chamada do simulador.

Não é necessário explicitar se os da dos do sistema estão guardados no disco ou não. A própria linguagem se encarrega de verificar onde se encontram os dados para simulação.

NB,, inicia os ponteiros da linguagem de entrada para receber novo bloco.

## 4.4.3 - Cartões de controle para o programa simulador

O programa que efetua a simulação do sistema possui também cartões de controle e estes são os seguintes:

TIPO 1 : Inicialização de sinais

TIPO 2 : Informações Gerais

Cartão de finalização

## a - Sequência de entrada dos cartões acima

A ordem é qualquer sendo que o cartão de finalização deve ser o último.

er deve her as ingelate correspondential as

## b - Função de cada cartão:

b.1 - <u>Cartões do TIPO 1</u>: estabelecimento de condições iniciais para os sinais. Estes cartões apresentam como característica o fato de possuirem nas duas primeiras colunas o código de condição inicial (CI).

Os cartões podem conter dados até a coluna 71. Os nomes de sinais não podem ser trunca dos e continuados em outros cartões. Deve-se colocá-los por extenso em novo cartão, se necessário, o qual deve ter as iniciais correspondentes ao tipo de cartão considerado.

#### COLUNA 1

CI pp XXXXXXX = Valor, YYYYYYY = Valor, .....

onde:

XXXXXX ou YYYYYY é nome do sinal a ter condição inicial seguido imediatamente do sinal = e de um nú mero cujo valor é ou "0" ou "1".

.Não é permitido brancos na descrição.

.Não existe cartão de continuação e o usuário deve começar a descrição de outros cartões, se necessário, sempre com o código CIDD sequindo-se os nomes dos sinais com seus valores.

## b.2 - Cartões do TIPO 2

# b.2.1 - Solicitação de impressão de sinais

Os cartões podem conter dados até a coluna 71. Os sinais não podem ser truncados e continuados em outros cartões. Deve-se colocálos por extenso em novo cartão, se necessário, o qual deve ter as iniciais correspondentes ao tipo de cartão considerado.

Os sinais que se deseja imprimir são fornecidos através do cartão:

#### COLUNA 1

RS pp xxxxxx, yyyyyy, zzzzzz, ..., wwwwww

onde:

XXXXXX, YYYYYY, ZZZZZZ, WWWWWW são os nomes dos sinais a imprimir.

Não existe cartão de continuação e o usuário deve colocar tantos cartões RS por quanto necessários.

## Observação:

- . Número máximo de sinais a imprimir= = 40
- . Havendo cartões para saida de formas de onda vertical, os dados solicitados para impressão serão ignorados.

## b.2.2 - Solicitação de formas de onda

Os cartões podem conter dados até a coluna 71. Os nomes de sinais não podem ser trun cados e continuados em outros cartões. Deve-se co locá-los por extenso em novo cartão, se necessário, o qual deve ter as iniciais correspondentes ao tipo de cartão considerado.

Pode-se solicitar a impressão da for ma de onda de sinais através dos cartões:

# b.2.2.1 - Forma de onda horizontal

#### COLUNA 1

PHMM, XXXXXX, YYYYYYY, ZZZZZZ, ..., WWWWWW

onde:

XXXXXX, YYYYYY, ZZZZZZ, WWWWWW são nomes dos sinais cujos gráficos são desejados.

. Não deve haver brandos na descrição.

.Não existe cartão de continuação e o usuário deve colocar tantos cartões PHDD quanto necessários.

## Observação;

.Número máximo de sinais para gráfico = 40.

#### b.2.2.2 - Forma de onda vertical

O formato é o mesmo que o anterior, a penas com as seguintes observações:

19) O código de saida gráfica é PV.

29) O número máximo de sinais para gráfico é 11.

### b.2.3 - Intervalo de impressão de sinais

Pode-se solicitar que o intervalo de impressão seja estabelecido a critério do usuá-rio. Isso é efetuado através do cartão:

## COLUNA 1

INTERVALO & DE & TEMPO & DØØØØØ

onde:

gggggg é o valor do intervalo em octal.

A ausência deste cartão é interpreta da pelo simulador como sendo o intervalo de tempo unitário.

Este cartão tem significado apenas no caso de se ter cartões RS na descrição.

## b. 2.4 - Tempo máximo de simulação

A duração da simulação é determinada pelo cartão;

COLUNA 1

TEMPO & FINAL & ØØØØØØ

onde:

ØØØØØØ é o valor do instante final de simulação, em octal.

A ausência deste cartão é interpreta da como simulação durante 10.000 intervalos unitários.

O usuário pode ainda, através de manuseio da chave Ø do painel, interromper o processamento quando o desejar.

### b.3 - Cartão de finalização

Este cartão é obrigatório e encerra a leitura de dados e informações para o simulador. Não havendo dados ou informações gerais o cartão de finalização será o único a ser lido pelo simula dor.

O formato deste cartão é o seguinte:

COLUNA 1 FIM

NOTA IMPORTANTE: Se os dados da estrutura foram ar quivados no disco através do cartão DI,, ou então automáticamente pela imagem de entrada e não foram destruidos, estes dados poderão ser simulados diretamente uti lizando-se o seguinte cartão:

:PR, SIMUL

Seguem-se os cartões de uso do si mulador.

### 4.5 - Controle de erros

4.5.1 - Erros detetados pela linguagem de entrada

### ROTINA DE CONVERSÃO

20 - conversão de dado alfabético

#### ROTINA DE BUSCA DE CARACTERES

- 22 dentro dos parênteses, encontrada uma virgula logo após o "("
- 30 primeiro caracter de um nome é "("
- 31 nome com mais de cinco caracteres
- 40 logo após ")" não tem virgula
- 41 dentro dos parênteses, encontrada mais que uma virgula

### ROTINA DE CONTROLE DE SINAIS

- 10 não encontrado nome de controle a analisar no cartão de dado.
- 11 o número de bits é diferente de 1
- 200 encontrado nome de sinal com "("
- 100 erro ou falta de nome de um sinal de um FF
- 101 não se especificou "fan-in" "fan-out" de um sinal num FF
- 102 um sinal foi utilizado como registrador

### ROTINA DE CONTROLE DE DIMENSÃO DE UM CARTÃO

500 - não se encontrou um \* na coluna 72 para indi car continuação

#### ROTINA PARA PESQUISAR CARTÕES DO TIPO CL OU CR

- 70 falta o nome do sinal de "clock" ou colocou-se parênteses no nome
- 71 não colocado o valor de "T" ou "TAU"

#### ROTINA PARA PESQUISA CARTÕES DO TIPO GP

- 901 não especificado o "0" ou "1" corretamente
- 9ø3 não especificado o nome do sinal do Gerador de palavras

## ROTINA PARA PESQUISAR CARTÕES DO TIPO FF

- 51 nome do sinal Q ou QB não especificado ou então não especificado "fan-in"/"fan-out" ou então não especificado o tipo do FF
- 52 encontrado um sinal "(" ou ")" no nome do sinal Q ou QB
- 53 não especificado TD01 ou TD10 do: clock ou set ou reset
- 54 erro na especificação da borda ou nível
- 55 função não existente

### ROTINA PARA PESQUISAR CARTÕES DO TIPO GT

- 5Øl não especificado o nome do bloco "GATE"ou sua função, ou ainda não especificado "fan-in" / "fan-out" ou atrasos do "GATE"
- 502 no nome do sinal existe delimitador "("ou ")"

e cochec astatement an earter act a de chiller

503 - não existe função especificada

#### ROTINA PARA PESQUISAR CARTÕES DO TIPO GB

- 700 erro no nome do bloco
- 701 não especificado o nome do bloco
- 702 nome do bloco ja existe
- 703 erro no nome de um sinal
- 704 foi gravado parte do bloco no disco (o tama nho do bloco ultrapassa a dimensão padrão)
- 705 não existe sinal especificado no cartão GB
- 706 tentativa de gravação do bloco com erro de en trada

## ROTINA PARA PESQUISAR CARTÕES DO TIPO BL

- 601 erro no nome do bloco
- 602 não especificado o nome do bloco
- 603 erro em nome de sinal
- 604 não há correspondência entre parâmetro especi ficado no BL e parâmetro do bloco gravado
- 605 faltam sinais na especificação do bloco
- 606 excedeu o número de sinais permitidos para o bloco

#### ROTINA PARA PESQUISAR CARTÕES DO TIPO DB

800 - erro no nome do bloco

#### PROGRAMA PRINCIPAL DA LINGUAGEM DE ENTRADA

42 - o código existente no cartão não é de controle ou indicativo de bloco

### 4.5.2 - Erros detetados pelo simulador

- 91 ERRO NA ROTINA DE DISCO.Não encontra dos arquivos para armazenamento de da dos
- ol sinal na lista de entrada para forma de onde ou imprimir ou dar condições iniciais, inexistentes

5. Exemplos de uso do programa de simulação

5.1 -Exemplos de utilização da linguagem de entrada e do simulador.

Apresentam-se nesta secção diversos exemplos de utilização, que podem auxiliar os que desejarem se familiarizar com o programa de simulação de sistemas digitais e servir-se dele.

A maior parte dos exemplos é cons tituida de portas lógicas e define uma estrutura que é gravada em disco para posterior utilização.

Apresenta-se ainda o exemplo do re lógio central de um computador em desenvolvimento no Labora tório de Sistemas Digitais, onde são utilizados vários blo cos representativos de pastilhas de circuitos integrados que constam da biblioteca do sistema e cujo tipo pode ser conhecido, atráves da consulta aos circuitos apresentados.

Os desenhos inclusos servem como referência para melhor compreensão dos blocos codificados.

5.1.1 Circuito (fig. 5.1) e cartões de descrição do: 74278

"four bit cascadable priority register"



申诉

\*\*/4278 - 4-BIT CASCADABLE PRIDRITY REGISTER

資金

GT, RB1, AND, 1, 1, 5, 5, 2, 01, STROB.,

GT, RB2, AND, 1, 1, 5, 5, 2, 02, STROB,,

GT, RB3, AND, 1, 1, 5, 5, 2, 03, STROB,,

GT. RB4, AND, 1, 1, 5, 5, 2, 04, STROB,,

61, SB1, AND, 1, 1, 2, 13, 2, DB1, STROB,,

GT, 582, AND, 1, 1, 2, 13, 2, DB2, STROB,,

GT, SB3, AND, 1, 1, 2, 13, 2, DB3, STROB,,

GT, SB4, AND, 1, 1, 2, 13, 2, DB4, STROB,,

GT, DB1, NUT, 1, 1, 6, 5, 1, D1,,

GT, DB2, NOT, 1, 1, 6, 5, 1, D2,

GT. DB3, NOT, 1, 2, 6, 5, 1, D3,,

GT, DB4, NOT, 1, 1, 6, 5, 1, D4,,

GT, NB1, NOR, 1, 10, 13, 5, 2, RB1, Q1,,

G1, QB2, NOR, 1, 10, 13, 5, 2, RB2, Q2,,

GT, QB3, NOR, 1, 10, 13, 5, 2, RB3, Q3,,

GT, QB4, NOR, 1, 10, 13, 5, 2, RB4, Q4,,

GT, 01, NUR, 1, 10, 5, 2, 2, SB1, QB1,,

GT, 02, NOR, 1, 10, 5, 2, 2, 582, UB2,

GT, U3, NOR, 1, 10, 5, 2, 2, 563, QB3,,

GT, Q4, NOR, 1, 10, 5, 2, 2, SB4, GB4,,

GT. Y1, NOR, 1, 14, 24, 10, 2, QB1, PU,,

GT, Y2, NOR, 1, 10, 20, 16, 3, QB2, Q1, PV,,

6T, Y3, NOR, 1, 10, 20, 16, 4, 483, 01, 92, P0,

GT, Y4, NOR, 1, 10, 20, 16, 5, 084, 01, 02, 03, P0,,

GT, P1, OR, 1, 10, 23, 30, 5, Q1, U2, Q3, Q4, PU,,

賣賣

食食

\*\* VAT ARMAZENAR BLOCD

賣市

GB, 8278, STRUB, PA, U1, U2, U3, D4, P1, Y1, Y2, Y3, Y4,

141500

5.1.2 Circuito (fig. 5.2) e cartões de descrição do: 74S113
"dual JK negative edge triggered flip-flop"



\*\*

\*\* 745113- DUAL J.K- NEGATIVE EDGE TRIGGERED FLIP, FLOP

黄黄

GT, IN1, NAND, 1, 10, 7, 1, 4, QH, CLEAR, J, CLOCK,

GT, IN2, NAND, 1, 10, 7, 1, 4, PRESE, Q, K, CLOCK,

GT, FLO, AND, 1, 10, 1, 2, 3, PRESE, CLOCK, GB,,

GT, FLI, AND, 2, 10, 1, 2, 3, QB, IN1, PRESE,,

GT, Q, NOR, 1, 16, 3, 1, 2, FLI, FLO,,

GT, FLUS, AND, 1, 10, 1, 2, 3, Q, CLEAR, CLOCK,

GT, FLIS, AND, 2, 10, 1, 2, 3, Q, IN2, CLEAR,

GT, DB, NOR, 1, 16, 3, 1, 2, FLIS, FLOS,,

安古

\*\* VAL ARMAZENAR BLOCO

\*\*

GB, S113, PRESE, CLEAR, CLOCK, J, K, Q, QB,

NB . .

5.1.3 Circuito (fig. 5.4) e cartões de descrição do: 7474
"dual D type edge triggered flip-flop"



安女

\*\*7474- DUAL D TYPE EDGE TRIGGERED FLIP-FLOP

資金

GT, Q1, NAND, 1, 1, 5, 5, 3, PRESE, Q4, Q2,

GT, Q2, NAND, 1, 3, 5, 5, 3, CLEAR, CLOCK, Q1,

GT, Q3, NAND, 1, 2, 5, 5, 3, Q2, CLOCK, Q4,,

GT, 04, NAND, 1, 2, 5, 5, 3, 03, CLEAR, DADO,,

GT, Q, NAND, 1, 11, 20, 15, 3, PRESE, Q2, QB,,

GT, 98, NAND, 1, 11, 20, 15, 3, 0, CLEAR, 93,

黄金

\*\* VAI ARMAZENAR BLOCO

. \*\*

GB. B7474, PRESE, CLEAR, CLUCK, DADO, 0, QB.,

NDP .

5.1.4 Circuito (fig. 5.3) e cartões de descrição do: 74158 "quadruple two input selector/multiplexer"



DATA 2- INPUT 74158 - QUADRUPLE

\*\*

\*\*/4158 - QUAURUPLE 2-INPUT SELECTOR/MULTIPLEXER

GT, AA1, AND, 1, 1, 7, 7, 3, A1, SELA, BSTR, GT, BB1, AND, 1, 1, 7, 7, 3, B1, SELB, BSTR, GT, AA2, AND, 1, 1, 7, 7, 3, A2, SELA, BSTR,, GT, BB2, AND, 1, 1, 7, 7, 3, 82, SELB, BSTR, GT, AA3, AND, 1, 1, 7, 7, 3, A3, SELA, BSTR, , GT, 883, ANU, 1, 1, 7, 7, 3, 83, SELB, BSTR,, GT, AAA, AND, 1, 1, 7, 7, 3, A4, SELA, BSTR, GT, 684, AND. 1, 1, 7, 7, 3, 84, SELB, BSTR, GT, Y1, NOK, 1, 10, 7, 7, 2, AA1, BB1,, GT, Y2, NOK, 1, 10, 7, 7, 2, AA2, BB2,, 51, Y3, NOK, 1, 10, 7, 7, 2, AA3, BB3,, GT, YA, NOR, 1, 10, 7, 7, 2, AAA, BB4,, GT, SELA, NOT, 1, 10, 8,9,1, SEL,, GI, SELB, NOT, 1, 14, 4, 1, 1, SELA,, GT, HSTR, NOT, 1, 10, 7, 6, 1, STR,,

\*\*

索宾

GB, R158, STR, SEL, A1, A2, A3, A4, B1, B2, B3, B4, Y1, Y2, Y3, Y4,

1.000

5.1.5 Circuito (fig. 5.4) e cartões de descrição: 74S74
"dual D type edge triggered flip-flop"

收货

\*\*74574= DUAL D= TYPE EDGE TRIGGERED FLIP= FLOP

賣賣

GT, 951, NAND, 2, 2, 2, 2, 3, PRESE, QS4, QS2,,

GT, US2, NANU, 2, 4, 2, 2, 3, CLEAR, US1, CLOCK,,

bT, 053, NAND, 1, 2, 2, 2, 3, CLOCK, QS2, QS4,,

61, 454, NAND, 1, 3, 3, 3, 3, CLEAR, DADO, QS3,,

GT, Q, NAND, 1, 13, 6, 2, 3, PRESE, QS2, QB, ;

GT, QB, NAML, 1, 13, 6, 2, 3, CLEAR, QS3, Q,,

由哦

\*\* VAI ARMAZENAR BLOCO

黄食

GB, S7474, PRESE, CLEAR, CLUCK, DADO, Q, QB,,

NBPP

5.1.6 Circuito (fig. 5.5) e cartões de descrição do:
9318
"eight input priority encoder"



FIG. 5.5

\*\*

\*\* 9318 - EIGHT INPUT PRIORITY ENCUDER

\* \*

GT, EBO, NAND, 1, 11, 11, 36, 9, INBO, INB1, INB2, INB3, INB4, INB5, INB6, INB7, E1,

GT, GSB, NAND, 1, 14, 9, 19, 2, EBG, E1,,

GT, SA1, AND, 1, 10, 12, 8, 5, INBB2, IN1, INBB4, INBB6, £1,

GT, SA2, AND, 1, 10, 12, 8, 4, INBB5, INBB4, IN2, E1,

GT, SA3, AND, 1, 10, 12, 8, 5, INBB4, IN3, INBB5, INBB6, E1,

GT, SA4, AND, 1, 10, 12, 8, 2, E1, IN4, ,

GT, SA5, AND, 1, 10, 12, 8, 3, E1, IN5, INBB6,,

GT, SA6, AND, 1, 10, 12, 8, 2, IN6, E1,,

GT, SA7, AND, 1, 10, 12, 8, 2, IN7, E1, ,

GT, ABU, NOR, 1, 10, 7, 9, 4, SA1, SA3, SA5, SA7,

GT; AB1, NOK, 1, 10, 7, 9, 4, SA2, SA3, SA6, SA7,

GT, AB2, NOR, 1, 10, 7, 9, 4, SA4, SA5, SA6, SA7,,

GT, IN1, NOT, 1, 10, 17, 23, 1, INB1,,

GT, IN2, NOT, 1, 10, 22, 16, 1, INB2,,

GT. INB82. NOT, 1, 10, 1, 1, 1, IN2,,

GT, IN3, NOT, 1, 10, 17, 23, 1, INB3,,

GI, INA, NOT, 1, 10, 22, 16, 1, INB4.,

GT. TNBR4, NOT. 1, 10, 1, 1, 1, 1, 1, 144,,

GT, INS, NOT, 1, 10, 22, 16, 1, INAS,,

GT, INBB5, NOT, 1, 10, 1, 1, 1, 1, IN5,,

GT, TN6, NOT, 1, 10, 22, 16, 1, INB6,,

GT, INBR6, NOT, 1, 10, 1, 1, 1, IN6,,

GT, IN7, NOT, 1, 10, 17, 23, 1, INB7,,

GT, E1, NOT, 2, 10, 9, 10, 1, E81,,

救救

\*\* VAI ARMAZENAR BLOCU

齿齿

GB, H9318, EB1, INB0, INB1, INB2, INB3, INB4, INB5, INB6, INB7, EB0, GSB, AB0, AB1,

AB2 . .

NB ,

5.1.7 Circuito (fig. 5.6) e cartões de descrição do:
74S175
"quadruple D type flip-flops with clear"



\*\*

\*\* 745175

QUADRUPLE FLIP-FLOP

貴貴

GT, CLEB, NOT, 1, 10, 4, 1, 1, CLEAR,,

GT, CLEBB, NOT, 1, 20, 1, 4, 1, CLEB,,

GT, CLUB, NOT, 1, 10, 1, 1, 1, CLUCK,,

GT, CLORB, NUT, 1, 20, 1, 1, 1, CLOB,,

GT. Q11, NAND, 1, 10, 2, 2, 2, Q12, Q14,,

GT, 012, NANU, 1, 18, 2, 2, 3, 011, CLOBB, CLEBB,,

GT, Q13, NAND, 1, 10, 2, 2, 3, Q12, CLOBB, Q14,,

GT, Q14, NAND, 1, 10, 8, 6, 3, Q13, D1, CLEBB,,

GT, U1, NANU, 1, 11, 12, 2, 2, 012, 081,,

GT, GB1, NAND, 1, 11, 12, 2, 3, Q1, CLEBB, Q13,

GT, 921, NAND, 1, 10, 2, 2, 2, 022, 024,,

GT, 1922, NAND, 1, 14, 2, 2, 3, 021, CLOBB, CLEBB, ,

GT, 023, NAND, 1, 10, 2, 2, 3, 022, CLOBB, 024,

GT. U24, NAND, 1, 10, 8, 6, 3, 023, 02, CLEBB,,

GT, 02, NANU, 1, 11, 12, 2, 2, 022, QB2,,

GT, QB2, NAND, 1, 11, 12, 2, 3, Q23, CLEBB, Q2,,

GT, 931, NAND, 1, 10, 2, 2, 2, 932, 934,,

GT, 032, NAND, 1, 10, 2, 2, 3, 031, CLOBB, CLEBB,,

GT, 033, NAND, 1, 10, 2, 2, 3, 032, CLOBB, 034,,

GT=034, NAND, 1, 10, H, 0, 3, U33, D3, CLEBB,,

GT, 03, NANU, 1, 11, 12, 2, 2, 032, 083,,

GT, QBS, NAND, 1, 11, 12, 2, 3, Q3, CLEBB, Q33,,

GT, 041, NAND, 1, 14, 2, 2, 2, 442, 944,,

GT, Q42, NAND, 1, 10, 2, 2, 3, Q41, CLOBB, CLEBB,,

GT, Q45, NAND, 1, 14, 2, 2, 3, Q42, CLOBB, Q44,

GT, Q44, NAND, 1, 10, 8, 6, 3, 943, 04, CLEBB,,

GT, 104, NANU, 1, 11, 12, 2, 2, 042, QB4,,

GT, OBA, NAND, 1, 11, 12, 2, 3, 94, CLEBB, 943,

黄寅

WW VAI AKMAZEMAK HLOCU

寅世

GB: S1/5, CLEAK, CLUCK, UI, 2, D3, 04, Q1, QB1, Q2, QB2, Q3, QB3, Q4, QB4,

5.1.8 Circuito (fig. 5.7) e cartões de descrição do: 3205

"high speed one out of eight binary decoder"



青青

\*\*3205 - 1 OUT OF 8 BINARY DECODER

\*\*

GT, ABM, NOT, 1, 10, 1, 1, 1, AM,,

GT, ABBO, NUT, 1, 10, 1, 1, 1, ABO,,

GT, AB1, NOT, 1, 10, 1, 1, 1, A1,,

GT, ABB1, NOT, 1, 10, 1, 1, 1, AB1,,

GT, AB2, NOT, 1, 10, 1, 1, 1, A2,,

GT, ABB2, NOT, 1, 10, 1, 1, 1, AB2,,

GT, E1, NOT, 1, 1, 1, 1, 1, E81,,

GT, E2, NOT, 1, 1, 1, 1, 1, EH2,,

GT, ENBL, AND, 1, 10, 1, 1, 3, E1, E2, E3,,

GT. SBO, NAND, 1, 6, 15, 16, 4, ABO, AB1, AB2, ENBL,,

GT, SH1, NAND, 1, 6, 16, 16, 4, ABB0, AB1, AB2, ENBL,,

GT, 382, NAND, 1, 6, 16, 16, 4, ABO, ABB1, AB2, ENBL,,

GT, SB3, NAND, 1, 6, 16, 16, 4, ABB0, ABB1, AB2, ENBL,

GT, SB4, NAND, 1, 6, 16, 16, 4, AB0, AB1, ABB2, ENBL,,

GT, SB5, NAND, 1, 6, 15, 15, 4, ABRU, AB1, ABB2, ENBL,

GT, SB5, NAND, 1, 6, 15, 16, 4, AB0, ABB1, ABB2, ENBL,

GT, SB1, NAND, 1, 6, 16, 16, 4, ABBU, ABB1, ABB2, ENBL,

黄黄

\*\* VAI ARMAZENAR BLOCO.

黄黄

GB, 83205, EB1, EB2, E3, A0, A1, A2, SB0, SB1, SB2, SB3, SB4, SB5, SB6, SB7,

\*\*

由女

\*\* PEDIDO DE LISTAGEM DOS BLOCUS

\* \*

黄青

LB,

### BIBLIOTECA DAS PASTILHAS EXISTENTES

| NUM.BL. | BLOCO | ORIGEM | TAM . MFUN | TAM . MSIMB |
|---------|-------|--------|------------|-------------|
| 4       | B278  | 0      | 6          | 3           |
| 2       | 5113  | 9      | 2          | 5           |
|         | 83205 | 13     | 4          | 3           |
| 3       | 87474 | 20     | 2          | 2           |
| 4       |       | 24     | A          | 3           |
| 5       | 8158  | 31     | 2          | 2           |
| 6       | 57474 |        | 6          | 4           |
| 7       | 89318 | 35     | 7          | 4           |
| 8       | \$175 | 45     | ,          |             |

EM CASO DE NECESSIDADE CONSULTE OS DADOS DE GERACAD DOS BLOCOS

5.1.9 Circuito (fig. 5.8) e cartões de descrição do: relógio central

5.1.10 Simulação do relógio central



\*\* DL=18 RELOGIO CENTRAL

\*\*

\*\* DESCRICAD DE LIGACOES E CIRCUITOS

由出

\*\* CHAMADA DE BLOCOS LOGICOS

會會

\*\*

GT, PREF, AND, 1, 12, 7, 8, 2, PREL, NLAL,

BL, S175, NLAL, PREF, PD, PA, NB, NC, PA, NA, PB, NB, NC, PC, ND, PD,

BL, S113, PRESE, NLAL, PREF, PA, NA, PE, NE,

BL, S113, PRESE, NLAL, PREF, PE, NE, PF, NF,

GT, SN1, NAND, 1, 12, 5, 5, 2, NPRO, SN2,

GT, SN2, NAND, 1, 12, 5, 5, 3, 5N1, SN3, NLAL,

GT, SN3, NOT, 1, 12, 5, 5, 1, SN4,

GT, SN4, NAND, 1, 12, 5, 5, 3, NSP16, NSP17, NSP23,

BL, S113, NLAL, CLEAR, PD, SN1, SN4, PRONT, NPRON,

GT, SN5, NAND, 1, 12, 5, 5, 3, NPRON, NCND, PDC31, 1.

GT, SN6, NAND, 1, 12, 22, 15, 2, PBCU, PPART,

BL, B7474, NLAL, CLEAR, PE, SN6, NUSA1, SN7,

BL, B7474, NLAL, CLEAR, PE, PBCU, NUSA2, NCU,

BL, S7474, PRESE, NLAL, NF, SN7, SN8, NUSA3,,

BL, S7474, NLAL, CLEAR, NF, SN8, NUSA4, SN9,

GT, PRCU, NAND, 1, 12, 5, 5, 2, 3N8, SN9,,

GT, SN10, NAND, 1, 12, 5, 5, 2, SN5, NCU,,

BL, S7474, PRESE, NLAL, NF, SN10, SN11, NUSA5,

GT, NBREC, NAND, 1, 12, 5, 5, 2, SN11, PRCU,

GT, SN12, NAND, 1, 12, 5, 5, 2, PA, NBREC,,

GT, PTA, NOT, 1, 12, 8, 7, 1, SN12,

GT, SN13, NAND, 1, 12, 5, 5, 2, PB, NBREC,,

GT, PTB, NOT, 1, 12, 8, 7, 1, SN13,,

GT, SN14, NAND, 1, 12, 5, 5, 2, PC, NBREC,,

GT, PTC, NOT, 1, 12, 8, 7, 1, 5N14,

GT, SN15, NAND, 1, 12, 5, 5, 2, PD, NBREC,

GT, PTD, NOT, 1, 12, 8, 7, 1, SN15,

GT, SN16, NAND, 1, 12, 5, 5, 2, PE, NBREC,

GT, PTE, NOT, 1, 12, 8, 7, 1, SN16,

GT, SN17, NAND, 1, 12, 5, 5, 2, PF, NBREC,

GT, PTF, NOT, 1, 12, 8, 7, 1, SN17,

GT, SN18, NAND, 1, 12, 5, 5, 2, PA, NBREC,

GT, SN19, NAND, 1, 12, 5, 5, 2, PE, NBREC,

GT, SN20, NAND, 1, 12, 5, 5, 2, SN18, SN19,

GT, NTO, NOT, 1, 12, 8, 7, 1, SN20,,

GT, PTO, NAND, 1, 30, 7, 7, 2, 5N18, 5N19,

食食

\*\*DADOS DE TESTES

会会

CR, NLAL, 2000, 1920,

CL, PREL, 50, 25,,

GP. 1, NPRO, 2, 300, 200, 400, 500,

GP, 1, NSP16, 2, 120, 380, 700,

CL, NSP17, 1400, 200,

CL, NSP23, 900, 500,,

CR, PBCU, 3000, 2100,,

CR, PPART, 3000, 900,

CL, PRESE, 3000, 2500,,

CL, CLEAR, 3000, 2500,,

GP,0,PDC31,2,120,380,100,300,300,

GP,0,NCND,2,120,380,100,300,300,

FI,

# SINAIS EXISTENTES

| 3066           | 1     | 1 | 3    |
|----------------|-------|---|------|
| PREF           | 2     | 3 | 2000 |
| PREL           | 3     | 3 | 2000 |
| NLAL           | 4     | 8 | 4    |
| PD             | 5     | 8 | 6    |
| PA             | 6     | 8 | 9    |
| NB             | 7     | 8 | 9    |
| NC             | 8     | 8 | 9    |
| NA             | 9     | 8 | 9    |
| PB             | 10    | 8 | 9    |
| PC             | 11    | 8 | 10   |
| ND             | 12    | 9 | 9    |
| 00000          | 13    | 9 | 8    |
| 99999          | 14    | 9 | 9    |
| 00000          | 15    | 9 | 12   |
| 99999          | 16    | 9 | 9    |
| 99999          | 17    | 9 | 7    |
| 99999          | 18    | 9 | 8    |
| 99999          | 19    | 9 | 8    |
| 99999          | 5.0   | 9 | 9    |
| 66666          | 21    | 9 | 8    |
| 00000          | 22    | 9 | 8    |
| 96696          | 23    | 9 | 9    |
| 99999          | 24    | 9 | 7    |
| 00000          | 25    | 9 | 8    |
| 99999          | 26 27 | 9 | 8    |
| 99999          | 28    | 9 | 9    |
| 99999          | 29    | 9 | 7    |
| 66666          | 30    | 9 | 8    |
| 66666          | 31    | 9 | 8    |
| PRESE          | 32    | 3 | 5000 |
| PE             | 33    | 8 | 5    |
| NE             | 34    | 8 | 11   |
| 66666          | 35    | 9 | 8    |
| 99999          | 36    | 9 | 8    |
| 69666          | 37    | 9 | 9    |
| 00000          | 38    | 9 | 9    |
| 99999          | 39    | 9 | 9    |
| 99999          | 40    | 9 | 9    |
| PF             | 41    | 8 | 11   |
| NF             | 42    | 8 | 3 8  |
| 66666          | 43    | 9 | 8    |
| 66666          | 44    | 9 | 9    |
| 66666          | 45    | 9 | 9    |
| 86666          | 46    | 9 | 9    |
| 66666          | 47    | 9 | 9    |
| 99999          | 48    | 1 | 10   |
| SN1            | 49    | 3 | 2000 |
| NPRO           | 51    | 1 | 11   |
| SN2            | 52    | i | 11   |
| SN3            | 53    | i | 10   |
| SN4            | 54    | 3 | 2000 |
| NSP16          | 55    | 3 | 2000 |
| NSP17          | 56    | 3 | 2000 |
| NSP23<br>CLEAR | 57    | 3 | 2000 |
| PRONT          | 58    | 8 | 12   |
| NPRON          | 59    | 8 | 11   |
| IN INCOM       |       |   |      |

| 99999  | 60  | 9 | 8    |
|--------|-----|---|------|
| 66666  | 61  | 9 | 8    |
| 06660  | 62  | 9 | 9    |
| 96696  | 63  | 9 | 9    |
| 99999  | 64  | 9 | 9    |
|        | 65  | 9 | 9    |
| SN5    | 66  | 1 | 11   |
| NCND . | 67  | 3 | 2000 |
| PDC31  | 68  | 3 | 5000 |
| 3N6    | 69  | 1 | 11   |
| PRCU   | 70  | 3 | 2000 |
| PPART  | 71  | 3 | 2000 |
| NUSAL  | 72  | 8 | 10   |
| SN7    | 73  | 8 | 9    |
| 99996  | 74  | 9 | 0    |
| 99999  | 75  | 9 | 0    |
| 66666  | 76  | 9 | 0    |
| 99999  | 77  | 9 | 0    |
| NUSA2  | 78  | 8 | 10   |
| NCU    | 79  | 8 | 9    |
| 96666  | 80  | 9 | 0    |
| 99999  | 81  | 9 | Ø    |
| 9999   | 82  | 9 | 0    |
| 99999  | 83  | 9 | 0    |
| SNB    | 84  | 8 | 10   |
| NUSA3  | 85  | 8 | 12   |
| 99999  | 86  | 9 | 0    |
| 99999  | 87  | 9 | 0    |
| 99999  | 88  | 9 | 0    |
| NUSA4  | 90  | 8 | 12   |
| SN9    | 91  | 8 | 11   |
| 99999  | 92  | 9 | 0    |
| 99999  | 93  | 9 | 0    |
| ***    | 94  | 9 | 0    |
| 90906  | 95  | 9 | 0    |
| PRCU   | 96  | 1 | 11   |
| SNIA   | 97  | 1 | 11   |
| SN11   | 98  | 8 | 11   |
| NUSA5  | 99  | 8 | 12   |
| 96969  | 100 | 9 | Ø    |
| 99999  | 101 | 9 | 8    |
| 99999  | 102 | 9 | . Ø  |
| 99999  | 103 | 9 | (8)  |
| NAREC  | 104 | 1 | 4    |
| SN12   | 105 | 1 | 11   |
| PTA    | 106 | 1 | 12   |
| SN13   | 107 | 1 | 11   |
| PTB    | 108 | 1 | 12   |
| SN14   | 109 | 1 | 11   |
| PTC    | 110 | 1 | 12   |
| SN15   | 111 | 1 | 11   |
| PTO    | 112 | 1 | 12   |
| SN16   | 113 | 1 | 11   |
| PTE    | 114 | 1 | 12   |
| SN17   | 115 | 1 | 11   |
| PTF    | 116 | 1 | 12   |
| SN18   | 117 | 1 | 10   |
| SN19   | 118 | 1 | 10   |
| 5N20   | 119 | 1 | 11   |
| NTO    | 120 | 1 | 12   |
|        |     |   |      |

30 121 PTØ SI,, 1

PV PTF, PTE, PTO, PTC, PTB, PTA, PT0, NT0, NBREC, PREL PV PRONT TEMPO FINAL 3340 FIM

|   |             |     |        |          | 0.50  | n=0 | DTA | 970 | NTØ | NBREC | PREL | PRONT |
|---|-------------|-----|--------|----------|-------|-----|-----|-----|-----|-------|------|-------|
|   |             | PTF | PTE 1  | PTO<br>1 | PTC 1 | PTB | PTA | PTØ | 0   | . 1   | 1    | 0     |
|   | I           | i   | i      | 1        | 1     | 0   | 0   | 1   | 0   | 1     | 1    | 8     |
|   | 1 - 10000   | 1   | 1      | 1        | 1     | N   | 0   | i   | 0   | i     | i    | 0     |
|   | 00002-      | i   | 1      | 1        | . 1   | 0   | 0   | 1   | 0   | 1     | 1    | 8     |
|   | 99993-      | 1   | 1      | 1 1      | 1     | 0   | 0   | î   | 0   | i     | i    | 0     |
|   | I           | 1   | 1      | 1        | 1     | 8   | 8   | 1   | 0   | 1     | 1    | 0     |
|   | 00004-<br>I | 1   | 1      | 1        | i     | 0   | 0   | i   | 0   | i     | 1    | 0     |
|   | 00005-      | 1   | 1      | 1        | 1     | Ø   | 0   | 1   | 0   | 1     | 1    | 1     |
|   | 90006-      | 1   | 1      | i        | i     | Ø   | 0   | i   | 0   | 1     | 1    | 1     |
|   | I           | 1   | 1      | 1        | 1     | 0   | 0   | 1   | 0   | 1     | 1    | i     |
|   | 00007=<br>I | 1   | 1      | 1        | î     | 0   | 0   | 1   | 0   | 1     | 1    | 1     |
|   | -86600      | 1   | 1      | 1        | 1     | 0   | 0   | 1   | 0   | i     | i    | i     |
|   | -66666      | 1   | i      | i        | i     | 0   | 0   | 1   | 0   | 1     | 1    | 1     |
|   | I<br>maine  | 1   | 1      | 1        | 1     | 0   | 0   | 1   | 0   | i     | i    | i     |
|   | I           | i   | i      | i        | 1     | 0   | 0   | 1   | 0   | 1     | 1    | 1     |
|   | 00011=      | 1   | 1      | 1        | 1     | 8   | 6   | 1   | 0   | i     | i    | i     |
|   | 00012-      | 1   | 1      | 1        | 1     | 0   | 0   | 1   | 0   | 1     | 1    | 1     |
|   | 00013=      | 1   | 1      | 1        | i     | 0   | 0   | i   | 0   | i     | i    | 1     |
|   | I           | 1   | 1      | 1        | 1     | 0   | 0   | 1   | 0   | 1     | 1    | 1     |
|   | 00014=<br>I | 1   | 1      | 1        | i     | 0   | 0   | i   | 0   | . 1   | i    | 1     |
|   | 00015=      | 1   | 1      | 1        | 1     | 8   | 0   | 1   | 8   | 1     | 1    | 1     |
|   | 00016-      | 1   | 1      | i        | i     | 0   | 0   | i   | 0   | 1     | 1    | 1     |
|   | I           | 1   | 1      | 1        | 1     | 0   | 0   | 1   | 0   | i     | i    | i     |
|   | 00017=<br>I | 1   | î      | i        | i     | 0   | 0   | 1   | 0   | 1     | 1    | 1     |
| 4 | 00018-      | 1   | 1      | 1        | 1     | 0   | 8   | 1   | 0   | 1     | 1    | î     |
|   | 00019-      | 0   | 8      | i        | i     | 0   | 0   | 8   | 0   | 1     | 1    | 1     |
|   | 00050-      | N N | Ø      | 1        | 1     | 0   | 0   | 0   | 0   | i     | i    | 1     |
|   | I           | Ŋ   | 0      | 1        | 1     | Ø   | 0   | Ø   | 0)  | 1     | 1    | 1     |
|   | 00021-      | 0   | N      | 1        | 1     | 0   | 10  | Ø   | 0   | i     | 1    | 1     |
|   | 88855       | 0   | 89     | 1        | 1     | 0   | 0   | 0   | 0   | 1     | 1    | 1     |
|   | 00023=      | 8   | 8      | 1        | i     | 0   | 0   | 0   | 0   | 1     | 1    | 1     |
|   | 00024=      | 0   | 9      | 1        | 1     | 0   | 0   | 8   | 0   | 1     | 1    | 1     |
|   | I           | 0   | Ø      | i        | i     | 0   | 0   | 8   | 0   | 1     | 0 1  | 1     |
|   | 00025-      | 8)  | 0      | 1        | 1     | 0   | 0   | 0   | 1   | 1     | 0    | 1     |
|   | 69656-      | 8   | Ø      | i        | i     | 0)  | 0   | 0   | 1   | 1     | 0    | 1     |
|   | 1 49927-    | Ø   | V)     | 1        | 1     | 0   | 0   | 0   | 1   | i     | 0    | i     |
|   | I           | N   | Ø      | 1        | 1     | 8)  | 0)  | 0   | 1   | 1     | 0    | 1     |
|   | NA028-      | N   | N<br>N | 1        | 1     | 0   | 0   | 0   | i   | i     | Ø    | 1     |
|   | 00029-      | 0   | Ŋ      | 1        | 1     | 0   | 0   | 0   | 1   | 1     | 0    | 1     |
|   | 00030=      | N   | 0      | 1        | 1     | 0   | 8   | 0   | 1   | 1     | 0    | i     |
|   | I           | Ø   | И      | 1        | 1     | 0   | 0   | 0   | 1   | 1     | 0    | 1     |
|   | 00031-<br>I | 8   | 64     | 1        | 1     | 89  | 8   | 0   | i   | 1     | 0    | i     |
|   |             |     |        |          |       |     |     |     |     |       |      |       |

|         |    |     |     |     |     |   |   |     | 1   | 0     |
|---------|----|-----|-----|-----|-----|---|---|-----|-----|-------|
|         |    |     |     |     |     | - |   |     | 1   | 0     |
|         |    |     |     |     | 0   | 0 | a | 1   | 1   | (O)   |
|         |    |     | 1   |     | 0   | 0 | 0 | 1   | 1   | Ø     |
|         |    | N   | •   |     | Ø   | 0 | 0 | i   | 1   | Ø     |
|         | ., | 0   | i   | i   | 0   | 0 | 0 | 1   | 1   | 0     |
| 4       | W  | 0   | 1   | 1   | 0   | 0 | 0 | 1   | 1   | 0     |
| 60132-  | 0  | 0   | 1   | 1   | 0   | 0 | 0 | 1   | 1   | 0     |
| I       | 0  | 0   | 1   | 1   | 0   | 0 | 0 | 1   |     | . 0   |
| 00133=  | 0  | O . |     |     | 0   | 0 | 0 | 1   |     | 0     |
| 40134-  | 0  | Ø   | 1   | 1   | 0   | 0 | 0 | 1   |     | 0     |
| 00134-  | 0  | V)  |     | 1   | 0   | 9 | 0 | 1   | 0   | 0     |
| 00135-  | 0  | Ø   | i   | i   | 0   | 0 | 1 | 1   |     | 0     |
| I       | 0  | N   | i   | i   | 0   | 0 | 1 | 1   |     | 0     |
| 00136-  | 0  | N   | 1   | 1   | 0   | 1 | 1 | 1   | 1   | . 0   |
| I       | 0  | 0   | 1   | 1   | Ø   | 1 | 1 | 1   |     | 0     |
| 09137-  | 0  | . 0 | 1   | 0   | 0   | 1 | 1 | 1   |     | . 0   |
| 00430-  | 8  | W   | 1   | 0   | 0   | 1 | 1 | 1   |     | CA CA |
| 00138=  | 0  | Ø O |     | 0   | 0   |   |   | 1   |     | 0     |
| 00139=  | 0  | Ø   | i   | 0   | Ø   | i | i | i   |     | 0     |
| 1       | Ø  | N   | i   | 0)  | 0   | i | 1 | 1   |     | . 0   |
| 001400  | 0  | 9   | 1   | 0   | 0   | 1 | 1 | 0   | 5   | 1 0   |
| I       | 0  | 0   | 1   | 0   | 0   | 1 | 1 | 0   |     | 1 0   |
| 00141-  | 0  | 0   | 1   | 0   | 0   | 1 | 1 | 0   |     | 0     |
| I       | 0  | 0   | 1   | 0   | 0   | 1 | 1 | Ø   | - 4 | 1 (2) |
| 00142=  | 0  | (V) | 1   | 0   | 0   | 1 | 1 | 0   |     | 1 0   |
| 00143-  | 0  | Ø   | 1   | 0   | 0   | 1 | 1 | 0   |     | 0     |
| I       | Ø  | Ø   | i   | Ø   | . 0 | i | i | 0   |     | 1 0   |
| 00144=  | 0  | 0   | 1   | 0   | 0   | 1 | 1 | Ø   |     | 1 0   |
| I       | 0  | N   | 1   | 10  | Ø   | 1 | 1 | 0   |     | 1 0   |
| 09145-  | 6  | N   | 1   | 0   | Ø   | 1 | 1 | 0   |     | 1 0   |
| I       | 8) | 0   | 1   | 0   | 0   | 1 | 1 | 0   |     | 1 0   |
| 00146=  | 80 | (A  | 1   | 0   | 0   | 1 | 1 | 0)  |     | 1 0   |
| 00147=  | 0  | N   | i   | Ø   | 0   | i | i | 0   |     | 1 0   |
| I       | 0  | U   | i   | 0   | 0   | 1 | 1 | Ç1  |     | 1 0   |
| 00148=  | 0  | Ø   | 1   | 0   | 0   | 1 | 1 | 0   |     | 1 0   |
| I       | Ø  | Ŋ   | - 1 | 0   | 0   | 1 | 1 | (0) | 1/2 | 9 0   |
| 00149=  | 0  | N   | 1   | 0   | 60  | 1 | 1 | (2) | 1 3 | 1 0   |
| 00150=  | 8  | 0   | 1   | 0)  | 0   | 1 | 1 | Ø   | 1 4 | 1 1   |
| TACTING | 0  |     | •   | 0   | 0   | • | 1 | 0   | 1   | 1 1   |
| 00151-  | N  | 0 1 | i   | Ø   | 0   | 1 | i | 0   |     | i     |
| I       | () | i   | i   | 0   | Ø   | i | 1 | 0   |     | 1 1   |
| 00152-  | 0  | 1   | 1   | 0   | 0   | 1 | 1 | 0   |     | 1 1   |
| I       | 0  | 1   | 1   | 0   | 0   | 1 | 1 | 0   |     | 1 1   |
| 00153=  | 0  | 1   | 1   | 0   | 0   | 1 | 1 | 0   |     | 1 1   |
| Got 5   | 0  | 1   | 1   | (A) | 0   | 1 | 1 | 0   |     | 1 1   |
| 00154-  | 9  | 1   | 1   | 0   | 0   | 1 | 1 | Ø   |     | 1 1   |
| 00155-  | 0  | 1   | 1   | 0   | N   | 1 | i | Ø   |     | i     |
| T       | 0  | 1   | 1   | 0   | 0   | i | i | 0   |     | 1 1   |
| 00156-  | 0  | i   | 1   | 0   | 0   | 1 | 1 | 98  |     | 1     |
| I       | 0  | 1   | 1   | 0   | 0.  |   |   |     |     |       |
| 00157-  | 8  | 1   | 1 . | a   |     |   |   |     |     |       |
| ,       |    |     |     |     |     |   |   |     |     |       |

| 01735=<br>01736=<br>101737=<br>101738=<br>101740=<br>101740=<br>101741=<br>101742=<br>101743=<br>101744=<br>101745=<br>101746=<br>101747=<br>101747=<br>101747=<br>101748=<br>101749=<br>101750=<br>101751=<br>101752= |                                         |                                         |                                         |           |         |         |       |                       |     |                       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|-----------|---------|---------|-------|-----------------------|-----|-----------------------|
| I<br>01749=<br>I<br>01750=<br>I<br>01751=<br>I                                                                                                                                                                         | 000000                                  | 8 8 8 8 8                               | 0 0 0 0                                 | 8 8 8 8 8 | 8 8 8   | 0 0 0   | 0 0   | 1 0 1 0 1 0 1 0 1 0   | 0 0 | 1 0 1 0 1 0 1 0       |
| 1<br>01753=<br>1<br>01754=<br>1<br>01755=                                                                                                                                                                              | 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 | 80<br>80<br>80<br>80<br>80              | 000000000000000000000000000000000000000 | 0 0 0 0   | 8 8 8 8 | 8 8 8   | 0 0 0 |                       |     |                       |
| 01756=<br>I<br>01757=<br>I<br>01758=<br>I                                                                                                                                                                              | 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 | N 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                         | 8 8 8 8   | 0 0 0 0 | 8 8 8 8 | 00000 | 1 0 1 0 1 0 1 0 1 0 0 |     | 1 0 1 0 1 0 1 0 1 0 1 |
| 01759-                                                                                                                                                                                                                 | 0                                       | Ø                                       | Й                                       | Ø         | 0       | 0       | 0     | 1 0                   |     | 1 0                   |

5.1.11 Exemplo de problemas detetados com "fan-in" e "fan-out".

CL, R, 7, 3,,

CL, S, 17, 12,,

GT, JOAD, AND, 1, 1, 1, 1, 1, 5,,

GT, FLIP, NAND, 2, 1, 1, 1, 2, JOAO, FLOP,,

GT, FLOP, NAND, 1, 1, 1, 1, 2, R, FLIP,

FI,

PROBLEMAS DE FANIN-FANOUT COM BLOCO JOAO PROBLEMAS DE FANIN-FANOUT COM BLOCO FLOP

#### SINAIS EXISTENTES

| R    | 1    | 3 | 1999 |
|------|------|---|------|
| S    | 2    | 3 | 1999 |
| JOAD | 3    | 1 | *1   |
| FLIP | 4 .: | 1 | 9    |
| FLOP | 5    | 1 | -1   |
| SI,  |      |   |      |

ERROS SUPRIMEM EXECUCAD E GRAVAÇÃO

CL, R, 7, 3,,

CL, S, 17, 12,,

GT, JOAO, AND, 1, 1, 1, 1, 1, 5,,

GT, FLIP, NAND, 1, 1, 1, 1, 2, JOAO, FLOP,,

GT, FLOP, NAND, 2, 1, 1, 1, 2, R, FLIP,,

FI,

PRUBLEMAS DE FANIN-FANOUT COM BLOCO FLIP

#### SINAIS EXISTENTES

| R    | 1 | 3 | 1998 |
|------|---|---|------|
| 5    | 2 | 3 | 1999 |
| JOAO | 3 | 1 | 0    |
| FLIP | 4 | 1 | =1   |
| FLUP | 5 | 1 | 0)   |
| SI,  |   |   |      |

ERROS SUPRIMEM EXECUCAD E GRAVACAD

5.1..12 Exemplos de outros tipos de erros detetados.

CL, 8, 10,5,,

CR, R, 10,5,,

由会

\*\* NAND FLIP FLOP

由电

GT, FLIP, NAND, 1, 1, 1, 1, 2, S, FLOP,

GT, FLOPFLOP, NAND, 1, 1, 1, 1, 2, R, FLIP,

FASE DE COMPILACAD-+ERRO NUM. 31 COLUNA: 9

CL, S, 10,5,,

CR, R, 10,5,,

黄蜂

\*\*NAND FLIP FLOP

会将

GT, FLIP, NAND, 1, 1, 1, 1, 2, S, FLOP,

GT, FLOP, NAND, 1, 1, 1, 1, 3, R, FLIP,

FASE DE COMPILACAD -- ERRO NUM. 10 COLUNA: 31

6. Observações Finais

the since we will be a selected to the send of the sen

CORNER COR SUR SECRETAR RESIDENCE AND PORTING THE PRESENCE OF THE PROPERTY OF

### 6. -Observações Finais

O programa para simulação em nível de portas lógicas mostrou-se, após os testes realizados e vários casos práticos processados, bastante eficiente.

Inúmeros problemas que escapam ao projetista puderam ser detetados pelo simulador e levaram a um reestudo do projeto lógico e sua correção.

Dalgoritmo utilizado mostrou-se bastante flexível pois foi aplicado indistintamente tanto na simulação em nível de portas lógicas como também no programa simulador a nível de registros, tendo-se obtido os resultados esperados nas duas aplicações. Com essa observação, pode-se antecipar a utilização da mesma filosofia do algoritmo em outras aplicações.

Os atrasos envolvidos na simulação foram limitados apenas aos valores fornecidos pelo usuário mas são em geral os próprios valores nominais fornecidos pelo fabricante. O programa simulador permite a análise de condições de funcionamento de um circuito atráves da variação dos valores de atraso, de seus blocos dentro dos limites de máximo e mínimo especificados pelo fabricante.

Essa anâlise poderia ser automatizada atraves de algumas modificações na estrutura de dados do simulador bem como no programa que trabalha com a simulação propriamente dita.

Essa alternativa levaria a um est<u>u</u> do exaustivo do comportamento do sistema sendo simulado.

Entretanto, os valores de atrasos utilizados dizendo respeito aos tempos "TD01" e "TD10", asso ciados com sua escolha atraves da rotina de simulação do bloco e do comportamento do programa principal, permitem de tetar durante o processo de simulação a maior parte dos e ventuais problemas que costumam escapar a atenção do mais experimentado projetista.

O algorítmo para verificação dos problemas de "fan-in" e "fan-out" apesar de simples aju dou na solução de problema de carga de blocos lógicos.

Uma melhoria poderia ser acres centada nos blocos de controle, dotando-os de características de maior poder e eficiência. Assim poderia ser a crescentado alguns blocos que exercem funções mais globais, como por exemplo: substituir a descrição de um de terminado bloco pela descrição que se segue ao controle, inserir um bloco cuja descrição aparece em seguida ao bloco simulado, retirar um determinado bloco da estrutura, substituir sinal de estímulo por outro cuja descrição se segue, etc.

Esses recursos adicionais serão incorporados ao sistema, que deverá então basear-se em um computador de maior porte.

## BIBLIOGRAFIA

- BREUER, M.A. <u>Design automation of digital systems</u>.
   Englewood Cliffs, Prentice-Hall, 1972. v.1 Theory and techniques.
- STEPHENSON, R.E. Computers simulation for engineers.
   Utah, University of Utah, 1971.
- 3. SZYGENDA, S.A; ROUSE, D.M & THOMPSON, E.D. "A model and implementation of a universal time delay simulator for large digital nets." In: SPRIN JOINT COMPUTER CONFERENCE, University of Missouri, 1970. Proceedings. Roela, Missouri, 1970, p. 207 216
- 4. BREUER, M.A. "Recent developments in the automated design and analysis of digital systems". Proceedings of the IEEE, 60(1): 12-27, jan.1972
- 5. LAKE, D.W. -"Logic simulation in digital systems". Com puter Design, 9(5): 77-83, May 1970.
- 6. CHU, Y. <u>Introduction to computer organization.Engle</u> wood Cliffs, Prentice-Hall, 1970.
- 7. TUNG, L.H. A unit delay logic timing simulator. IBM Systems Development Division, Endicott Laboratory, TD 01.509. Endicott, IBM, 1969.
- 8. SCHEFF, B. H. "A machine aids system for digital de signers. "Computer Design, 8(10): 76-81, oct. 1969.

- 9. HOWIE, H.R., TAVAN, R.M. The on-line logical simu lation system. Cambridge, M.I.T., Charles Stark Draper Laboratory.
- 10. BERETEVAS, T., LIU, C.H. & TAYLOR, R.L. "A general purpose design automation file systems". In:DESIGN AUTOMATION WORKSHOP. 4th, 1966. Proceedings.
- 11. McCLUSKEY, E.J. Introduction to the theory of swit ching circuits. New York, McGraw-Hill, 1965.
- 12. TEXAS INSTRUMENTS INC. The TTL data Book for design engineers. 1971.
- 13. FAIRCHILD SEMICONDUCTOR TTL data book. California, Fairchild, 1972.
- 14. HEWLETT PACKARD Disc operating system HP 02116-91748.

  New Jersey, Hewlett Packard, 1969.

| DEVOLVER NAULTIMA DATA MARCA |  |  |  |  |  |  |
|------------------------------|--|--|--|--|--|--|
| 5-10-70 04 OUT 1999          |  |  |  |  |  |  |
| 26-01-23                     |  |  |  |  |  |  |
| 13.2-13                      |  |  |  |  |  |  |
| 25.7.43                      |  |  |  |  |  |  |
| 6/12/21                      |  |  |  |  |  |  |
| 5.5.35                       |  |  |  |  |  |  |
| 25/6/26                      |  |  |  |  |  |  |
| 24/5/77                      |  |  |  |  |  |  |
| 15/6/77                      |  |  |  |  |  |  |
| 29/9/19                      |  |  |  |  |  |  |
| 3-48-79                      |  |  |  |  |  |  |
| 25/11/86                     |  |  |  |  |  |  |
| 27/9                         |  |  |  |  |  |  |
| 5/10                         |  |  |  |  |  |  |
| 10/4/01                      |  |  |  |  |  |  |
| 18 FEV 1999                  |  |  |  |  |  |  |
|                              |  |  |  |  |  |  |
|                              |  |  |  |  |  |  |

Tearrens ic

FT-441

AUTOR: Massola, A. M. A.

TÍTULO: Automação de projetos de...

| N.o     | RETIRADA | DEVOL /DREW    |
|---------|----------|----------------|
| 3004/89 | 9/8/90   | DEVOL/PREVISTA |

FT-441

Massola, Antonio Marcos da A. Automação de projetos je sistemas digitais.

Serviço de Bibliotecas
Biblioteca de Engenharia Elétria